Presentation is loading. Please wait.

Presentation is loading. Please wait.

© 2008 Wellesley Information Services. All rights reserved. The Top 20 Tricks for Obtaining Faster SAP NetWeaver BI Response Time Dr. Bjarne Berg MyITgroup.

Similar presentations


Presentation on theme: "© 2008 Wellesley Information Services. All rights reserved. The Top 20 Tricks for Obtaining Faster SAP NetWeaver BI Response Time Dr. Bjarne Berg MyITgroup."— Presentation transcript:

1

2 © 2008 Wellesley Information Services. All rights reserved. The Top 20 Tricks for Obtaining Faster SAP NetWeaver BI Response Time Dr. Bjarne Berg MyITgroup Ltd. A VIP consulting company

3 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation  Management and Costs EarlyWatch Reports Wrap-up 2

4 Introduction In this session we will cover the top 20 must-do technical performance tricks to help you optimize SAP NetWeaver ® Business Intelligence (SAP NetWeaver BI) reporting for your end users. We will look at performance modeling of InfoCubes, how to improve memory utilization by caching and how to use diagnostics to analyze performance issues. We will also explore best practices on how to develop and manage aggregates and MultiProviders, and see what the SAP NetWeaver BI Accelerator can do for your organization. Finally, we will look at how to analyze EarlyWatch reports from Solution Manager 4.0 so they become actionable. 3

5 Capacity and Scalability Is the Top Concern for Your CxO Don’t undersize your global BI system  Spend adequate funding on hardware, memory, processing power and disk space 4 Source: Intel, SAP & Business Week "Seizing the BI Opportunity" 2006. A survey of 353 top C-level officers in large companies, reported that the top BI concern was the scalability of their solutions.

6 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation  Management and Costs EarlyWatch Reports Wrap-up 5

7 6 Problem: To reduce data volume in each InfoCube, data is partitioned by Time period. A query now has to search in all InfoProviders to find the data (e.g., billing docs from 2007). This is very slow. Solution: We can add “hints” to guide the query execution. In the RRKMULTIPROVHINT table, you can specify one or several characteristics for each MultiProvider which are then used to partition the MultiProvider into BasicCubes. If a query has restrictions on this characteristic, the OLAP processor is already checked to see which part cubes can return data for the query. The data manager can then completely ignore the remaining cubes. An entry in RRKMULTIPROVHINT only makes sense if a few attributes of this characteristic (that is, only a few data slices) are affected in the majority of, or the most important, queries ( SAP Notes: 911939. See also: 954889 and 1156681). Tip 1: MultiProviders and Hints

8 Tip 2: The Secret about MultiProviders & Parallel Processing To avoid an overflow of the memory, parallel processing is cancelled as soon as the collected result contains 30,000 rows or more and there is at least one incomplete sub process  The MultiProvider query is then restarted automatically and processed sequentially  What appears to be parallel processing corresponds to sequential processing plus the preceding phase of parallel processing up to the termination Generally, it’s recommended that you keep the number of InfoProviders of a MultiProvider to no more than 10. However, even at 4–5 large InfoProviders you may experience performance degradation. 7

9 MultiProviders and Parallel Processing (cont.) Consider deactivating parallel processing for those queries that are MultiProvider queries and have large result sets (and “hints” cannot be used).  With SAP BW 3.0B SP14, SAP BW 3.1 SP8, and later versions, you can change the default value of 30,000 rows — refer to SAP Notes 629541, 622841, 607164, and 630500. A larger number of base InfoProviders is likely to result in a scenario where there are many more base InfoProviders than available dialog processes, resulting in limited parallel processing and many pipelined sub-queries 8 You can also change the number of dialogs (increase the use of parallel processing) in RSADMIN by changing the settings for QUERY_MAX_WP_DIAG.

10 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation  Management and Costs EarlyWatch Reports Wrap-up 9

11 Aggregates Aggregates are much less used by the SAP installation base than training and common sense should dictate. The interface to build the summary tables (aggregates) is intuitive and easy to master, but few are taking real advantage of them. Even among those that are using aggregates, many have poorly defined solutions and seldom monitor the usage, thereby limiting the benefits of this simple technology. 10 To avoid poor definition and usage, aggregates should be developed after the system has been in production for a while and real user statistics are captured.

12 Tip 3: Building Aggregates Is Easy — Propose from Statistics 11 Select the run time of queries to be analyzed (e.g., 20 sec) Select time period to be analyzed  Only those queries executed in this time period will be reviewed to create the proposal This example shows how to build aggregates by using system statistics to generate proposals Note: To make this work, the BW statistics must be captured. Bjarne: Any sensitive or proprietary info on any of the screenshots in this file? BERG: No

13 Correct Aggregates Are Easy to Build – Propose from Query 12 We can also create proposals for aggregates based on individual queries that are performing poorly. We can also create proposals from the Query user statistics. To make this work, a representative number of queries must be executed to gather the statistics to optimize from.

14 Tip 4: Reduce the Number of Overlapping Proposals 13 We reduce the overlapping proposals by optimizing them. This may reduce the proposals from 99 to less than a dozen Bjarne: You’ve got a considerable amount of text that is hidden behind the screenshot. It really won’t fit conveniently outside of the graphic. Could you eliminate it or split this slide or otherwise correct? BERG: Fixed High valuation and high usage is what we are looking for. This indicates high reduction of records in aggregate and high benefits to users.. When using 3 rd party query tools and ODBC to query directly into the DSO, you are bypassing the OLAP Processor. Therefore, you cannot accurately performance tune the system using aggregates (statistics), nor will the 3 rd party tool benefit from aggregates.

15 Activate the Aggregate The process of turning 'on' the aggregates is simple

16 Fill Aggregate with Summary Data

17 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation  Management and Costs EarlyWatch Reports Wrap-up 16

18 Tip 5: Use the Correct Read Mode for Queries Select the right read mode. Three query read modes in BW determine the amount of data to be fetched from a database: 1. Read all data (all data is read from a database and stored in user memory space) 2. Read data during navigation (data is read from a database only on demand during navigation) 3. Read data during navigation and when expanding the hierarchy Reading data during navigation minimizes the impact on the application server resources because only data that the user requires will be retrieved. 17 Source: Catherine Roze, MyITgroup

19 Tip 6: Query Read Mode for Large Hierarchies For queries involving large hierarchies with many nodes, it would be wise to select Read data during navigation and when expanding the hierarchy option to avoid reading data for the hierarchy nodes that are not expanded. Reserve the Read all data mode for special queries — for instance, when a majority of the users need a given query to slice and dice against all dimensions, or when the data is needed for data mining. This mode places heavy demand on database and memory resources and might impact other SAP BW processes and tasks. A query read mode can be defined either on an individual query basis or as a default for new queries using the query monitor (transaction RSRT). 18 Source: Catherine Roze, MyITgroup

20 Tip 7: Condition and Exceptions Minimize conditions-and-exceptions reporting. Conditions & exceptions are usually processed by the SAP application server. This generates additional data transfer between database and application servers. If conditions and exceptions have to be used, the amount of data to be processed should be minimized with filters. When multiple drill-downs are required, separate the drill-down steps by using free characteristics rather than rows and columns. This strategy results in a smaller initial result set, and therefore faster query processing and data transport as compared to a query where all characteristics are in rows. 19 This strategy does not reduce the query result set. It just separates the drill-down steps. In addition to accelerating query processing, it provides the user more manageable portions of data. Source: Catherine Roze, MyITgroup

21 Some Performance Settings for Query Execution This decides how many records are read during navigation. 20 Examine the request status when reading the InfoProvider New in SAP NetWeaver 7.0 BI: OLAP Engine can read deltas into the cache. Does not invalidate existing query cache. Displays the level of statistics collected. Turn off/on parallel processing When will the query program be regenerated based on database statistics

22 Tip 8: Filters Leverage filters as much as possible. Using filters contributes to reducing the number of database reads and the size of the result set, thereby significantly improving query runtimes. Filters are especially valuable when associated with “big dimensions” where there is a large number of characteristics such as customers and document numbers. 21 If large reports have to be produced, leverage the BEx Broadcaster to generate batch reports and pre-deliver them each morning to their email, PDF or printer.

23 Tip 8: Use RSRT Transaction to Examine Slow Queries 22 P1 of 3

24 Look for Patterns and See the Performance Details 23 P2 of 3 In this real case, aggregates were needed for those cubes flagged …

25 Real Example: This System Has Issues with the Oracle DB 24 P3 of 3 Work with the Basis team to research the settings and the Oracle issues. Focus on SAP notes and the index issue. The RSRT and RSRV t- codes are a gold mine for debugging and analyzing slow queries.

26 Look at the Query Details for Each Slow Query 25 Notice the yellow flag for the 6 base cubes in the MultiProvider and the yellow flag for the 14 free chars. (Note: no hints were used in this MultiProvider, which led to very poor performance). Notice the yellow flag for the 6 base cubes in the MultiProvider and the yellow flag for the 14 free chars. (Note: no hints were used in this MultiProvider, which led to very poor performance). You can also trace the front-end data transfers and OLAP performance by using RSTT in SAP 7.0 BI (RSRTRACE in SAP BW 3.5)

27 Tip 9: Use the BEx Broadcaster to Pre-Fill the Cache 26 Distribution Types You can increase query speed by broadcasting the query result of commonly used queries to the cache. Users do not need to execute the query from the database. Instead the result is already in the system memory (and hence much faster). You can increase query speed by broadcasting the query result of commonly used queries to the cache. Users do not need to execute the query from the database. Instead the result is already in the system memory (and hence much faster).

28 Tip 10: Debugging Queries — Transaction RSRT 27 Here you can execute the query and see each breakpoint, thereby debugging the query and see where the execution is slow. Worth a try: Try running slow queries in debug mode with parallel processing deactivated to see if they run faster...

29 Tip 11: Upgrade to SAP NetWeaver Application Server- Java Service Pack 14 ASAP. 28 In Service Pack 14 we find several performance improvements including: - Better Java execution and performance - Increased OLAP cache abilities (Enhanced Cluster table - BLOB) In SAP NetWeaver BI 7.0, at all service packs up to number 14, it is also impossible to populate the OLAP cache by broadcasting query views. If you use earlier service packs, you may be forced to create many different queries to provide this performance. The implementation of Service Pack 14 is highly recommended by SAP for these performance reasons. When implemented, the Java execution will also improve.

30 A Real Example 29 This company saw a 39% decrease in query execution time after implementing SP14. They had 38 cockpits and 82 queries that improved substantially without any further changes.. Bjarne: I doctored the graphic somewhat to make it fit – is that ok? BERG: OK (cool effect )

31 30 1. When Restrictive Key Figures (RKF) are included in a query, conditioning is done for each of them during query execution. This is very time consuming and a high number of RKFs can seriously hurt query performance Recommendation: Reduce RKFs in the query to as few as possible 2. Line item dimensions are basically fields that are transaction oriented and therefore, once flagged as a ‘line item dimension’, is actually stored in the fact table. This results in faster query access (no table join). Tip 12: Restrictive Key Figures and Line Item Dimensions Explore the use line item dimensions for fields that are frequently conditioned in queries.

32 Tip 13: Reducing the Query Processing Time 31 Problem: Calculated Key Figures (CKF) are computed during run-time, and a high number of CKFs can slow down the query performance. Solution:Many of the CKF can be done during data loads & physically stored in the InfoProvider. This reduces the number of computations and the query can use simple table reads instead. Problem: Sorting the data in reports with large result sets can be time consuming. Solution: Reducing the number of sorts in the default view can improve the report execution & provide the users with data faster. PS: Reducing the text in query will also speed up the processing some!

33 32 Web templates in SAP BI can become really large. Since they contain both scripts and Cascading Stylesheets (CSS), the code can become really comprehensive. To reduce the CSS, you can try several compression tools that may help you limit the overall size of your web templates. There are no lack of free tools available, and the quality varies. Therefore you must remember to test, test, and test … (but the benefits can also be great). Compression tools for CSS and Java scripts can reduce the overall web template size. If you have thousands of users, this can be a ‘life saver’’ Tip 14: Make your web templates Smaller

34 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation EarlyWatch Reports Wrap-up 33

35 Tip 15: Is the Memory Cache Is Set Too Low? Cache has a system default of 100 MB for local and 200 MB for global cache. This may be too low for a system that can be optimized via broadcaster. 34 The Cache is not used when a query contains a virtual key figure or virtual characteristics, or when the query is accessing a transactional DSO, or a virtual InfoProvider Review the settings with the Basis team and look at the available hardware. Use transaction RSCUSTV14 in SAP NetWeaver BI to increase the cache. Focus particularly on the global cache.

36 Tip 15: Monitor and Adjust Cache Size To monitor the usage of the cache, use transaction code RSRCACHE and also periodically review the analysis of load distribution using ST03N – Expert Mode 35 The size of OLAP Cache is physically limited by the amount of memory set in system parameter rsdb/esm/buffersize_kb. The settings are available in RSPFPAR and RZ11. Source: V. Rudnytskiy, 2008

37 Tip 16: The Right OLAP Cache Persistence Settings 36 CACHE OLAP Persistence settings NoteWhenWhatt-code DefaultFlatfile Change the logical file BW_OLAP_CACHE when installing the system (not valid name)FILE OptionalCluster tableMedium and small result sets RSR_CACHE_DBS_IX RSR_CACHE_DB_IX Optional Binary Large Objects (blob)Best for large result sets RSR_CACHE_DBS_BL RSR_CACHE_DB_BL SP 14 Blob/Cluster Enhanced (new in SAP 7.0 BI) No central cache directory or lock concept (enqueue). The mode is not available by default. Set RSR_CACHE_ACTIVATE_NEW RSADMIN VALUE=x Source: SAP AG 2008.

38 Monitor Memory Usage — Do You Need More? 37 Roll memory was never maxed out in the period 12/23/07 through 1/27/08 Paging memory was never maxed out in the period 12/23/07 through 1/27/08 Extended memory was never maxed out in the period 12/23/07 through 1/27/08 Only 3GB of 9 GB of Heap memory was ever used in the period 12/23/07 through 1/27/08 Bjarne: Was heap really closer to 10GB? BERG: Crazy setting (it is PG&E)

39 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation  Management and Costs EarlyWatch Reports Wrap-up 38

40 Tip 17: Avoid Outdated Indexes and Database Statistics Database statistics are used by the optimizer to route queries. Outdated statistics leads to performance degradation. Outdated indexes can lead to very poor search performance in all queries where conditioning is used (i.e., mandatory prompts). for high volume InfoCubes, or cubes that have a high number of users, the percentage used to build DB stats can be increased from the default 10% to 20%. This may yield more accurate query routing and better query performance (consider this especially for cubes with “old data” partitioned) Real example

41 Tip 18: Avoid Replicating the Transaction System in SAP NetWeaver BI It is tempting to load cross-reference tables and do lookups inside SAP NetWeaver BI instead of extending extractors. This creates DSOs that cannot be queried efficiently without many table joins. In this example, ¼ of all DSOs contains less than 9 fields, and six have less than 4. Programs that can help you monitor the system design: 1.SAP_ANALYZE_ALL_INFOCUBES 2.ANALYZE_RSZ_TABLES 3.SAP_INFOCUBE_DESIGNS As much logic as possible should be moved to the extraction, and needed data fields should be denormalized and stored in logically organized ODSs and Infocubes. Real example

42 InfoCube Design and Indexes When you flag a dimension as “high cardinality” SAP NetWeaver BI will use a b-tree index instead of a bit-map index. This can be substantially slower if the high cardinality does not exist in the data in general (star-joins cannot be used with b-trees). 41 Validate the high-cardinality of the data and reset the flag if needed – this will give a better index type and performance Real example

43 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation EarlyWatch Reports Wrap-up 42 Bjarne: Which slides are meant be in the BIA “Management and Costs” section? BERG: Fixed

44 Tip 19: Use SAP NetWeaver BI Accelerator ASAP The accelerator makes query response time 50– 10,000 faster. You use process chains to maintain the HPA engine after each data load 43 HP, Sun and IBM have standard solutions ranging from $32K to $250K+ (+ SAP license fees) that can be installed and tested in as little as 2-4 weeks SAP BW Any tool Breaking news : 32 Gb Blades are now certified by SAP (July 2008)

45 How Does SAP NetWeaver BI Accelerator Work? 44 Currently, the accelerator performs aggregation and data selection for the query, all other processing is done by the OLAP analytical engine. (this means that 99% of the previous recommendations in this session still holds true) The accelerator is not used when the result set exceeds 3 million records (max. default). When the result set is less, the data is sent as one large data package to the application server (need fast network). In the next SAP NetWeaver release the accelerator will handle more of the analytics processing (such as “top-5 products sales”) which is currently done in the OLAP analytical engine. You can get accelerator sizing estimates by running the SAP program available in SAP Note: 917803

46 Performance Benchmarks for SAP NetWeaver BI Accelerator 45 The accelerator currently reads data from InfoCubes. DSOs & InfoObjects are still read from base/physical tables (even when the InfoObject is indexed as part of master data). The accelerator’s strength resides in its near-linear scalability. Performance is measured in terms of: 1.Accelerator index creation time 2.Multi-user throughput per hr. 3.Average report response time 4.Average number of records touched by each report.

47 46 The accelerator should be sized for critical applications. Most companies use the accelerator only for Production, while others have a complete landscape A Real Client Example from 2008

48 SAP NetWeaver BI Accelerator Is Becoming Mainstream 47 Once you exceed a few hundred critical users and/or 3-4 Tb of data you should seriously consider SAP NetWeaver BI Accelerator It is no longer something exotic. Many of the large SAP NetWeaver BI systems have already implemented the accelerator and many more projects are under way in Europe and in the Americas. Some of SAP reference clients Bjarne: Do we have permission to reproduce these company logos? BERG: It is all from SAP (they are reference customers on their web site) [added reference] Source: SAP AG

49 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation  Management and Costs EarlyWatch Reports Wrap-up 48

50 Tip 20: SAP Solutions Manager — EarlyWatch Reports Are Great! EarlyWatch reports provide a simple way to confirm how your system is running and to catch problems  A “goldmine” for system recommendations Run them periodically and read the details This is a real EarlyWatch report from a mid-sized company that has been running SAP BW for the last four years 49 On a large global project, system issues can be hard to pin down without access to EarlyWatch reports. The monitoring reports allows you to tune the system before the user community gets access and complaints arise.

51 EarlyWatch Performance Information 50 In a 24-hour operational systems due to time-zones, you will have less time to react and fix issues. Therefore, early detection of system issues are critical to the success of a global project. In a 24-hour operational systems due to time-zones, you will have less time to react and fix issues. Therefore, early detection of system issues are critical to the success of a global project.

52 EarlyWatch Reports — Finds Oracle Fixes In this real example, we can see that the EarlyWatch report has identified that the system is several Oracle notes behind in applying those needed to optimize DB performance. Before this was done, this system took 24 to 26 minutes to execute some queries. 51 Real example Bjarne: I rewrote the first bullet – is it ok? BERG: OK

53 EarlyWatch Reports — Finds Backup Problems In this real example, the EarlyWatch report identified that there were no valid backups for almost one month. 52 Real example

54 What We’ll Cover … Introduction Performance Issues and Tips  MultiProviders and Partitioning  Aggregates  Query Design and Caching  Hardware and Servers Designing for Performance  InfoCubes and DSOs SAP NetWeaver BI Accelerator  Sizing and Implementation EarlyWatch Reports Wrap-up 53

55 7 Key Points to Take Home Use best practices for query design before you start massive hardware performance tuning efforts. Plan for growth – what is the plan when you have 200, 500, or 1,000+ users? Start with aggregates (poor man’s SAP NetWeaver BI Accelerator), thereafter go with caching. Monitor the system usage — do you need more app servers, memory, hardware? Check database statistics and indexes and keep them up to date. If you are building an Enterprise Data Warehouse, plan and budget for a SAP NetWeaver BI Accelerator installation. EarlyWatch reports are a tool to live (and ‘die’) by. Use the report before you have performance issues. 54

56 Resources Dr. Bjarne Berg's web page -- 75+ presentations, tutorials & articles http://csc-studentweb.lrc.edu/swp/Berg/BB_index_main.htm SAP SDN Community web page for Business Intelligence Performance Tuning https://www.sdn.sap.com/irj/sdn/bi-performance-tuning ASUG407 - SAP BW Query Performance Tuning with Aggregates by Ron Silberstein (requires SDN or Marketplace log-on). 54 min movie. https://www.sdn.sap.com/irj/sdn/go/portal/prtroot/docs/media/uuid/d9fd 84ad-0701-0010-d9a5-ba726caa585d Large scale testing of SAP BI Accelerator on a NetWeaver Platform https://www.sdn.sap.com/irj/sdn/go/portal/prtroot/docs/library/uuid/b00 e7bb5-3add-2a10-3890-e8582df5c70f 55

57 Your Turn! 56 How to contact me: Dr. Bjarne Berg bberg@myitgroup.com

58 Disclaimer SAP, R/3, mySAP, mySAP.com, xApps, xApp, SAP NetWeaver ®, Duet ™, PartnerEdge, and other SAP products and services mentioned herein as well as their respective logos are trademarks or registered trademarks of SAP AG in Germany and in several other countries all over the world. All other product and service names mentioned are the trademarks of their respective companies. Wellesley Information Services is neither owned nor controlled by SAP. 57


Download ppt "© 2008 Wellesley Information Services. All rights reserved. The Top 20 Tricks for Obtaining Faster SAP NetWeaver BI Response Time Dr. Bjarne Berg MyITgroup."

Similar presentations


Ads by Google