Автор: Luca Biondi, Check SQL Server Plan Cache Pollution (II) in 45 Seconds
Вы исправили ad-hoc запросы, но ваш сервер всё ещё «колбасит»? В этой статье я расскажу, почему даже идеальная параметризация может привести к «токсичности повторного использования» (reuse toxicity) и массовым скачкам ЦП.
В двух словах
- Параметризованное засорение (Parameterized Pollution): Засорение кэша — это не только «слишком много планов», но и повторно используемый «неправильный план».
- Токсичность повторного использования (Reuse Toxicity): План, оптимизированный для одной строки, принудительно применяется к набору из миллиона строк, убивая производительность.
- Нестабильность планов (Plan Instability): Резкие колебания между
min_worker_timeиmax_worker_timeуказывают на войну, вызванную Sniffing'ом параметров. - Решение: Используйте Query Store, идентификацию по
query_hashи оптимизацию PSP в SQL Server 2022.
В предыдущей части этой серии мы очистили кэш от «мусорных» планов. Но горькая правда в том, что чистый код не гарантирует чистый кэш. Даже когда ваше приложение на 100% параметризовано, SQL Server всё ещё может страдать от другого вида засорения — логической токсичности. Это происходит, когда движок повторно использует неоптимальный план выполнения, потому что во время компиляции он «унюхал» (sniffed) непредставительный параметр.
