Blitz Result: Slow Storage Reads or Writes
SQL Server feels the need – the need for speed. Storage speed, to be more specific. One of the most common bottlenecks is underperforming storage subsystems.
SQL Server tracks read and write speeds for each database file – both data and log files. This part of our SQL Server sp_Blitz script checks sys.dm_io_virtual_file_stats looking for average read stalls (latency) over 100 milliseconds and average write stalls over 20 milliseconds. This script breaks it down by file.
What exactly is a bad number here? That’s a really good question, and it’s open for debate. Here’s a few thoughts:
- Microsoft SQL Customer Advisory Team – in point #4 in their Top 10 OLTP Issues, they suggest that reads over 15ms are a bottleneck and that log file writes should be 1ms or less. Keep in mind that this team usually deals with high-performance environments, though – not every SQL Server can afford to be quite this fast.
- Quest Perfmon poster – we worked with several other SQL Server experts to build this poster. We came up with a goal of <20ms for reads and <4ms for cached writes (storage with battery-backed cache).
No matter whose guidelines you pick, I’ve got bad news: you’re already doing worse. You arrived at this page because you have database files that are taking over 100ms for reads and/or 20ms for writes.
To Fix the Problem
There’s two ways to fix slow storage: make the storage go faster, or ask the storage do to less work.
The second option – asking storage to do less work – is usually the easiest way to start. By dropping unused indexes, we can insert/update/delete data faster, run backups faster, do DBCCs faster, and even do index rebuild jobs faster. By using the right indexes, we can avoid storage-intensive table scans and do less data juggling in TempDB. To learn more about that, check out our index tuning resources.
Want to learn more? We’ve got video training. Our VMware, SANs, and Hardware for SQL Server DBAs Training Video is a 5-hour training video series explaining how to buy the right hardware, configure it, and set up SQL Server for the best performance and reliability. Here’s a preview: