Power BI Report Refresh Performance Analyzer
To understand why a Power BI report refresh takes too much time, we can use SQL Server Profiler. SQL Server Profiler can be connected to a Power BI report in Power BI Service (must be in a Premium workspace) using XMLA Endpoints. Read Connecting SQL Server Profiler to Power BI Premium by Chris Webb and for more details.
It can also be connected to a Power BI report in Power BI Desktop. The easiest way is to add a button to the External Tools toolbar. Download https://github.com/avatorl/PowerBI/blob/main/performance/sqlserverprofiler.pbitool.json, put it into the C:\Program Files (x86)\Common Files\Microsoft Shared\Power BI Desktop\External Tools folder, then open Power BI.
data:image/s3,"s3://crabby-images/34d2c/34d2c7095c7d84b051840a66ef8d8c4dfafe149c" alt=""
The problem is that an SQL Server Profiler trace is not easy to analyze as is.
data:image/s3,"s3://crabby-images/315a7/315a79d03829abe3645c7f3ccba1e9f1b21c01b6" alt=""
Look at the above table and try to answer the following questions: Which queries take more time to refresh? Are queries being refreshed simultaneously? How do Power BI report options, such as Parallel loading of tables, affect the refresh?
data:image/s3,"s3://crabby-images/9e661/9e66119a609e85df32d36ad3fec7d749dd265e36" alt=""
It would be helpful to visualize the trace. Since data visualization is our passion and our data visualization tool is Power BI, I created the Power BI Report Refresh Performance Analyzer.pbit Power BI report template.
Export the SQL Server Profiler trace into an XML file:
data:image/s3,"s3://crabby-images/3da77/3da77d3ed3442404861e7c89a5cbc3c13a9c1acf" alt=""
Then open the report template and enter the path to the Trace XML file.
data:image/s3,"s3://crabby-images/631b6/631b642b4e233556d6da3ed89305e3b216452b4c" alt=""
Now you can see what is happening during the Power BI report refresh. The report shows a bar chart with the refresh duration for each object (tables, in some cases – columns), as well as a Gantt chart with the relative refresh time (relative to the refresh start).
data:image/s3,"s3://crabby-images/8bbf5/8bbf538bd11aabbca7e460d94aedd788384ff37c" alt=""
You can change the “Minimal Object Refresh Duration, seconds” parameter to exclude small objects that take less than the entered value in seconds to refresh.
data:image/s3,"s3://crabby-images/5c71a/5c71a4e2e531c091f2d8b69d971952a7ce5ffaf8" alt=""
You can try report refreshing with different Data Load options and export multiple SQL Server Profiler traces.
data:image/s3,"s3://crabby-images/d9f7d/d9f7de5d25246b479bf6b92977c383687070294e" alt=""
data:image/s3,"s3://crabby-images/21ff6/21ff6c1e47530d41483d604e4aed1fe5fb16a999" alt=""
The examples in this post have been created using Custom = 6 value.
2024-07-06 UPDATE
I’ve read Visualise your Power BI Refresh, realized what is missing and added 2 more columns. Thanks to Phil Seamark.
Rows Loaded – number of rows loaded into the table
Time to load 1K rows, s – time to load 1K rows (only for tables with 1K+ rows that take more than 1s to load)
Power BI Report Refresh Performance Analyzer.pbit Power BI report template
data:image/s3,"s3://crabby-images/88611/88611a9a793db2752702fb1e9a1be24dffef9fe4" alt=""