Analyzing Performance Problems Using XEvents, DMVs & Query Store

Slides:



Advertisements
Similar presentations
The Essentials: DMV’s and T-SQL for the DBA Rocky Mountain Tech Tri-Fecta.
Advertisements

Utility Database Chris
Chris Testa-O’Neill EMC Consulting. Agenda Resource Governor Integrating Performance Monitor and Profiler Policy Based Management Performance Data Collector.
Module 18 Monitoring SQL Server 2008 R2. Module Overview Monitoring Activity Capturing and Managing Performance Data Analyzing Collected Performance Data.
Key Concepts About Performance Factors Affecting SQL Performance SQL Performance Tuning Methodologies SQL Performance Tuning Tools 1.
Danette Dineen Riviello Magellan Health March 17,
Ideas to Improve SharePoint Usage 4. What are these 4 Ideas? 1. 7 Steps to check SharePoint Health 2. Avoid common Deployment Mistakes 3. Analyze SharePoint.
Module 10: Monitoring ISA Server Overview Monitoring Overview Configuring Alerts Configuring Session Monitoring Configuring Logging Configuring.
Learningcomputer.com SQL Server 2008 – Profiling and Monitoring Tools.
SQLRX – SQL Server Administration – Tips From the Trenches SQL Server Administration – Tips From the Trenches Troubleshooting Reports of Sudden Slowdowns.
1. When things go wrong: how to find SQL error Sveta Smirnova Principle Technical Support Engineer, Oracle.
ESRI User Conference 2004 ArcSDE. Some Nuggets Setup Performance Distribution Geodatabase History.
Troubleshooting SQL Server Performance: Tips &Tools Amit Khandelwal.
Msdevcon.ru#msdevcon. ИЗ ПЕРВЫХ РУК: ДИАГНОСТИКА ПРИЛОЖЕНИЙ С ПОМОЩЮ ИНСТРУМЕНТОВ VISUAL STUDIO 2012 MAXIM GOLDIN Senior Developer, Microsoft.
Diagnosing Performance with Wait Statistics Robert L Davis Principal Database
Why Should I Care About … The Plan Cache? Tuning When Stakeholders Won’t Say Where It Hurts.
SQL Server 2016 – New Features Tilahun Endihnew March 12, 2016.
SQL Advanced Monitoring Using DMV, Extended Events and Service Broker Javier Villegas – DBA | MCP | MCTS.
Improve query performance with the new SQL Server 2016 query store!! Michelle Gutzait Principal Consultant at
You Inherited a Database Now What? What you should immediately check and start monitoring for. Tim Radney, Senior DBA for a top 40 US Bank President of.
No more waiting. Sponsors About me  Database Technology Specialist  MVP  Blogger  Author 3
Session Name Pelin ATICI SQL Premier Field Engineer.
MANAGEMENT DATA WAREHOUSE AND DATA COLLECTOR Ian Lanham.
3 Methods to End the Madness
An introduction to Wait Statistics
You Inherited a Database Now What?
Automated Restore Script Output for Ola Hallengren’s Maintenance Solution 1) Start SQL Services on Local 2) Connect to Azure AlwaysOn 3) Delete all maintenance.
A big party is being held to honor relational database systems and their impact on modern society. Outside the venue, the host awaits the guests. The.
Troubleshooting SQL Server high CPU usage
Are You There, DBA? It’s Me, The App Developer.
SQL Server Data Collector From Every Angle
Building a Performance Monitoring System using XEvents and DMVs
Building a Performance Monitoring System using XEvents and DMVs
Using Extended Events to Diagnose Application Issues
SQL Server Monitoring Overview
Reading Execution Plans Successfully
AlwaysOn Availability Groups 101
Root Cause Analysis with DMVs
Auditing in SQL Server 2008 DBA-364-M
Peeking into the Plan Cache with SQL Server 2008
Performance Monitoring Using Extended Events, DMVs & Query Store
Introducing the SQL Server 2016 Query Store
Introducing the SQL Server 2016 Query Store
Building a Performance Monitoring System using XEvents and DMVs
Troubleshooting SQL Server Basics
Getting To Know Your Indexes
SQL Server on Linux Troubleshooting tips and tricks
The Ultimate Maintenance Plan By Ed Roepe Perimeter DBA, LLC
Introducing the SQL Server 2016 Query Store
SQL Server 2016 Query Data Store
Azure SQL Database - Managing your database on the cloud
Enterprise Auditing with SQL Server Audit
මොඩියුල විශ්ලේෂණය SQL Server Waits. Tables රැසක් එකට එකතු කිරීම.
Targeting Wait Statistics with Extended Events
Indexing For Optimal Performance
Dynamic Management Views a practical overview!
Moving from SQL Profiler to xEvents
You Inherited a Database Now What?
Kris Hokanson That’s bad mmmkay! …Or, how to know when your SQL Server isn’t working as well as it could.
Go, go Query Store! Gail Shaw.
Dynamic Management Views a practical overview!
Jean Joseph DBA/Developer
Building a Performance Monitoring System using XEvents and DMVs
Server-Side Programming
Denis Reznik SQL Server 2017 Hidden Gems.
Using wait stats to determine why my server is slow
Advanced Database Topics
Analyzing Performance Problems Using XEvents, DMVs & Query Store
Inside the Database Engine
Inside the Database Engine
Presentation transcript:

Analyzing Performance Problems Using XEvents, DMVs & Query Store Ola Hallengren, Principal Database Architect, Saxo Bank

Principal Database Architect, Saxo Bank Ola Hallengren Principal Database Architect, Saxo Bank ola@hallengren.com Microsoft MVP – Data Platform Author of the popular maintenance scripts at https://ola.hallengren.com Database Consultant

Thanks to our sponsors

Agenda Extended Events, DMVs and Query Store How are they working in different scenarios? How can you use them together? Comparing performance data Troubleshooting performance problems Experiences from the bank and when working with customers

Extended Events in a query or stored procedure execution Level Reads Writes CPU time Dura-tion Result sql_batch_completed Outer Yes OK/Abort/Error rpc_completed module_end Module * - sp_statement_completed Statement Only fires if completed successfully sql_statement_completed * A module could be a stored procedure or a function

A stored procedure was timing out – What statement was executing? You are looking at a rpc_completed event with result = Abort, and a module_end event. What statement was executing when the timeout happened? module_end tsql_frame Successful execution: <frame … line="0" offsetStart="-1" offsetEnd="-1“ /> Aborted execution: <frame … line="6" offsetStart="74" offsetEnd="202“/> You can pass the sql_handle to sys.dm_exec_sql_text to retrieve the sql text, and then use the offsets to calculate the statement Demo

Using Extended Events Histograms for troubleshooting connection pooling Real-world case: You have recently started to get more connection timeouts, expecially from one application. The developers are saying that they are using connection pooling, but how can you check it? The Extended Event login has a column is_cached. If you filter on is_cached = 0 you get connections where a real physical connection is established (so a non-pooled connection). Using a histogram target you can find out about which applications and host names that have the most non-pooled connections. Demo

Query Store – The basics The typical use case for Query Store is to look at changes to query plans. Automatically stores queries, query plans, run_time statistics and wait statistics. Run_time statistics and wait statistics are aggregated for one hour intervals. Stored by execution type: Regular, Aborted, and Exception Query Store data stored in the user database

Query_id – The starting point for Query Store analysis Real-world case: A critical report timed out last night. You have the application name, the host name, and the timestamp. Unfortunately the error message in the application was not very clear, and you are not sure what the query was. Limitation: Query Store does not have any information about application name, host name or login name. How can you find the query in Query Store? You need some additional data to find the query: sys.dm_exec_requests: statement_sql_handle and statement_context_id Extended Events: sql_handle, start_offset, and end_offset in tsql_frame Unfortunately there is no statement_context_id Extended Events. Demo

Using context_setting_id to find the correct query_id for your business application Real-world case: Some days later another critical report times out. This time you know the name of the stored procedure. You are thinking that it should be easy to find the query in Query Store and maybe force a good plan. To your surprise there are several query_id’s for the same object_id and query_text_id in sys.query_store_query. Only the context_setting_id is different. It turns out that some developers have been executing the stored procedure in SSMS to try to find out about the problem. SSMS has different set_options than the application. Again you need statement_context_id in sys.dm_exec_requests. Demo

Killed sessions not in Query Store runtime and wait statistics Real-world case: A query has been running for a long time. There is no command timeout in the application, so eventually you have to kill it. You look in the Query Store to compare the plans, but you can’t find any Aborted executions. Limitation: Executions are not captured in the Query Store sys.query_store_runtime_stats and sys.query_store_wait_stats, if a session is killed or if the client application or host is restarted or crash. The plan is still captured in sys.query_store_plan. Demo

Navigating XEvents, DMVs and Query Store Look at DMV snapshots for the same session_id, within the interval for the Extended Event XEvent start time <= DMV snapshot time <= XEvent end time Extended Events: rpc_completed sql_batch_completed module_end wait_completed DMV snapshots sys.dm_exec_sessions sys.dm_exec_requests sys.dm_exec_session_wait_stats sys.dm_os_waiting_tasks sys.sysprocesses Start time = timestamp – duration End time = timestamp statement_sql_handle and statement_context_id sql_handle, start_offset, and end_offset in tsql_frame (statement_context_id is missing) Query Store

A parallel query is running – Where are the reads in sys A parallel query is running – Where are the reads in sys.dm_exec_requests? Real-world case: A parallel query has been running for a long time. You suspect that it is doing a lot of reads, but the reads and logical_reads in sys.dm_exec_requests are 0. What is going on? Limitation: When a parallel query is running, the reads, logical_reads, and writes in sys.dm_exec_requests, are only updated for the coordinator thread. sys.sysprocesses.physical_io can be used as a workaround. That is updated for all child threads. Demo

A serial query is running – When are the DMVs updated? elapsed_time cpu_time reads logical_reads writes sys.dm_exec_requests Continuously sys.dm_exec_sessions When the request ends

A parallel query is running – When are the DMVs updated? elapsed_time cpu_time reads logical_reads writes sys.dm_exec_requests Continuously Continuously for the coordinator thread When the statement ends for the child threads sys.dm_exec_sessions When the request ends If the statement, request and session end at the same time, you will never see the reads, logical_reads and writes

Looking at log writes and availability group synchronizations in Extended Events, DMVs and Query Store Real-world case: You are troubleshooting an issue with slow transactions. You are collecting data from Extended Events, DMVs, and you are also looking in Query Store. The durations just do not add up. Limitation: Query Store, sys.dm_exec_query_stats, and the statement - level Extended Events do not include the hardening of the log writes to disk, or the synchronizations with the secondary replica in availability groups. Demo

Durations – Log writes and AG synchronizations Duration includes transaction log writes to disk Duration includes AG synchronizations * sql_batch_completed Yes rpc_completed module_end sp_statement_completed No sql_statement_completed Only if outside a module_end Query Store sys.dm_exec_query_stats sys.dm_exec_procedure_stats * Availability groups with synchronous-commit

A comparison between Query Store and DMVs Level Includes Where is it stored? Interval Query Store Statement All executions, except killed In memory  User database 1 hour (default) sys.dm_exec_query_stats Successful executions only In memory No interval sys.dm_exec_procedure_stats Stored procedure All executions Bonus slide

How recompiles and FREEPROCCACHE affects Query Store and DMVs Recompile triggered by statistics update or index rebuild sp_recompile DBCC FREEPROC CACHE Query Store Not affected sys.dm_exec_query_stats Stats reset plan_generation_num updated Entry removed All entries removed sys.dm_exec_procedure_stats Bonus slide

How recompile hints affects Query Store and DMVs Are stored procedures WITH RECOMPILE included? Are queries with OPTION (RECOMPILE) included? Query Store Yes sys.dm_exec_query_stats No Only last execution sys.dm_exec_procedure_stats Bonus slide

Looking at problems back in time How do you answer questions like “Why did this stored procedure time out last night?” When you are investigating problems back in time, the key thing is to have the data. For Query Store the data collection happens automatically in the user database. We have seen that in many cases the data collected in Query Store is not enough. Often you also need data from Extended Events and DMVs. For Extended Events and DMVs, you need to do the collection of data, or use a monitoring tool. You are welcome to use my monitoring scripts: https://ola.hallengren.com/scripts/PerformanceStore.zip

Questions? The presentation and demo code is available at https://www.pass.org Monitoring scripts: https://ola.hallengren.com/scripts/PerformanceStore.zip You can contact me at ola@hallengren.com