SQL SERVER – Guest Post – Glenn Berry – Wait Type – Day 26 of 28
- by pinaldave
Glenn Berry works as a Database Architect at NewsGator  Technologies in Denver, CO. He is a SQL Server MVP, and has a whole  collection of Microsoft certifications, including MCITP, MCDBA, MCSE,  MCSD, MCAD, and MCTS. He is also an Adjunct Faculty member at University  College – University of Denver, where he has been teaching since 2000.  He is one wonderful blogger and often blogs at here.
I am big fan of the Dynamic Management Views (DMV) scripts of Glenn. His script are extremely popular and the reality is that he has inspired me to start this series with his famous DMV which I have mentioned in very first  wait stats blog post (I had forgot to request his permission to re-use the script but when asked later on his whole hearty approved it).
Here is is his excellent blog post on this subject of wait stats:
Analyzing  cumulative wait stats in SQL Server 2005 and above has become a popular  and effective technique for diagnosing performance issues and further  focusing  your troubleshooting and diagnostic  efforts.  Rather than just  guessing about what resource(s) that SQL Server is waiting on, you can  actually find out by running a relatively simple DMV query. Once you  know what resources that SQL Server is spending the  most time waiting on, you can run more specific queries that focus on  that resource to get a better idea what is causing the problem.
I  do want to throw out a few caveats about using wait stats as a  diagnostic tool. First, they are most useful when your SQL Server  instance is experiencing  performance problems. If your instance is running well, with no  indication of any resource pressure from other sources, then you should  not worry that much about what the top wait types are. SQL Server will  always be waiting on some resource, but many wait  types are quite benign, and can be safely ignored. In spite of this, I  quite often see experienced DBAs obsessing over the top wait type, even  when their SQL Server instance is running extremely well.
Second,  I often see DBAs jump to the wrong conclusion based on seeing a  particular well-known wait type. A good example is CXPACKET waits.  People typically  jump to the conclusion that high CXPACKET waits means that they should  immediately change their instance-level MADOP setting to 1. This is not  always the best solution. You need to consider your workload type, and  look carefully for any important “missing”  indexes that might be causing the query optimizer to use a parallel  plan to compensate for the missing index. In this case, correcting the  index problem is usually a better solution than changing MAXDOP, since  you are curing the disease rather than just treating  the symptom.
Finally, you should get in the habit of clearing out your cumulative wait stats with the  DBCC  SQLPERF(‘sys.dm_os_wait_stats’, CLEAR); command.  This is especially  important if you have made an configuration or index changes, or if  your workload has changed recently. Otherwise, your cumulative wait  stats will be polluted with the old stats from weeks or months ago  (since the last time SQL Server was started or the stats  were cleared).  If you make a change to your SQL Server instance, or  add an index, you should clear out your wait stats, and then wait a  while to see what your new top wait stats are.
At any rate, enjoy Pinal Dave’s series on Wait Stats.
This blog post has been written by Glenn Berry (Twitter | Blog)
Read all the post in the Wait Types and Queue series.
Reference: Pinal Dave (http://blog.SQLAuthority.com)
Filed under: Pinal Dave, PostADay, Readers Contribution, SQL, SQL Authority, SQL Query, SQL Server, SQL Tips and Tricks, SQL Wait Stats, SQL Wait Types, T SQL, Technology