SQL Server性能问题排查指南
1. 内存问题排查
典型的OLTP应用具有大量请求,理想情况下,这些请求应从缓存中获取数据,否则可能出现内存瓶颈和I/O问题。以下是需要验证的规则:
- 规则1:平均页面寿命期望值应大于300秒
- 检测方法 :使用系统监视器的“SQL Server: Buffers Manager: Page life expectancy”性能计数器来识别这种情况。
- 解决方案 :
1. 确定是否存在外部内存压力。外部内存压力由系统上的其他内存消费者引起,可能是物理或虚拟的。调查是否可以移除服务器上运行的其他进程,或考虑添加更多内存。若虚拟内存不足,检查并增大交换文件的大小。
2. 确定内部内存压力的原因。可以使用 sys.dm_os_memory_clerks 和 sys.dm_os_memory_objects 等动态管理视图(DMV)来识别内存消费者,并确保SQL Server正常使用。
3. 检查并在必要时修改与内存相关的服务器配置选项,如每个查询的最小内存、服务器最小内存、服务器最大内存和启用AWE。可以使用默认跟踪来跟踪这些选项的可能修改。
4. 验证服务器上的工作负载是否显著增加。如果有大量会话或查询,内存消耗可能是正常的。
5. 检查是否缺少索引。非常大的表上缺少索引可能会导致与缓存相关的问题。
- 规则2:留意平均页面寿命期望值突然下降50%或更多的情况
-
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



