Analyzing database performance on Microsoft SQL Server is quite a complex issue. In dbWatch Control Center, our primary aim is first to provide structure and toolsets to avoid running into performance problems in the first place.
Consistency in deploying preventative maintenance routines should take care of many problems that occur over time, such as index and table fragmentation. Bad statistics are a foundation that will ensure that we don’t waste time investigating preventable causes.
As most DBAs will know, unexpected performance issues can occur even with the best foundation, and we will need to be able to investigate the underlying causes.
For this reason, dbWatch Control Center has a lot of monitoring jobs focused on monitoring the behavior of different performance metrics. At its core, all performance issues occur when resource limits are met. It can be the CPU, disk, memory, or internal database limits.
The first we need to do to start our investigation is to find the time window where the performance issues occurred. The typical problem is that one or more SQL statements cause an overload of the database resources in the time period in which they were running. In this blog, we will briefly investigate performance issues due to SQL statements.
In the SQL Performance section in the management module of dbWatch Control Center, you can look at historical resource usage, together with the SQL statements that were performed in that time period.
In this section, we can see spikes in logical/physical reads and writes. This often, but not always, coincide with performance loads. We can also look at other metrics in the same time frame, such as Time, the elapsed time for all queries in a time frame, which could indicate slow query response. The Waits could indicate spikes where the database is waiting for specific resources. CPU, where we can see any spike in CPU load. Data cache where we can see if there was a fight for memory resources and other graphs focusing on metrics that could be relevant.
Once a peak has been identified, you can use the mouse to zoom in on the time period.
The SQL performance dashboard will then zoom in, and looking at the SQL handle statistics, it’s easy to see what SQL handle is responsible for this peak.
You can then right-click and select show statistics, to open the SQL handle and view the SQL code, statistics, and when the SQL statement is inside that SQL handle.
If we here are interested in the SQL statement in this SQL handle that is causing the most logical reads, we can quickly identify it in the list and right-click to show this SQL statement or open the query plan in SQL Server Management Studio for further investigation.
If we choose the “Show SQL statement and statistics,” we can open the SQL statement.
In this case, it was the fetch statement in the procedure. We can see in the SQL code for the procedure that this is the select_cur which is defined as:
/*cursors*/
DECLARE select_cur CURSOR FOR
SELECT * FROM dbw_test_tab
DECLARE @col1 INT, @col2 VARCHAR(1000)
This allows us quickly to see what is going on, in this case, a select statement from a performance load routine, so nothing is out of what we expected.
If this was interesting, we go more in-depth on the SQL performance dashboard on the wiki page, wiki.dbwatch.com (https://wiki.dbwatch.com/ControlCenter/1.0/en/topic/using-sql-performance-package)
With dbWatch Control Center, SQLServer DBAs can now monitor their resource usage trend and analyze the peak hours in their database environment based on available charts.
dbWatch Control Center assists SQLServer DBAs in efficiently running their databases, from proactive database performance monitoring to managing SQLServer tasks.
Control Center also helps SQLServer DBAs play back their historical performance to drill down and pinpoint problematic queries during the past few weeks.
Control Center offers the following:
- Farm overview – consolidated views for performance, capacity, and maintenance for your entire database farm
- Monitor in-depth all your instances and platforms
- Performance – identify performance bottlenecks within the farm
- Scalability – ability to adapt to your growing database farm
- Alerting – alerting and third-party extensions tailored to your business requirements
- Security – role-based access controls, Active Directory, and Kerberos integration encrypts connections and support security certificates
You can try dbWatch Control Center today. Use this link to download a version of Control Center that can monitor up to 5 instances for free: Download dbWatch Control Center
If you have any questions or you would like to know more about how dbWatch Control Center can assist you in your current enterprise database monitoring and database management situation, feel free to contact me directly: per.christopher@dbwatch.com
For more information, visit www.dbWatch.com or the dbWatch wiki pages