SQL Server数据库服务器CPU不能全部利用原因分析

0    23    1

Tags:

👉 本文共约1396个字,系统预计阅读时间或需6分钟。

背景

客户凌晨把HIS数据库迁移到配置更高的新服务器,上午业务高峰时应用非常缓慢。

现象1

通过SQL专家云实时可视化界面看到大量的绿点,绿点表示会话在等待某项资源,绿点越大说明等待的会话数越多。

SQL Server数据库服务器CPU不能全部利用原因分析

进入活动会话列表,发现大量会话的状态为runnable,runnable代表这个会话可以执行,但没有 CPU 可以分配给它,可以理解为正在等待 CPU 这项系统资源。

SQL Server数据库服务器CPU不能全部利用原因分析

但是此时服务器的CPU利用率并不高,在30%左右。

SQL Server数据库服务器CPU不能全部利用原因分析

从任务管理器里查看,服务器有128核心,但是绝大多数核心根本利用不上。

本人提供Oracle(OCP、OCM)、MySQL(OCP)、PostgreSQL(PGCA、PGCE、PGCM)等数据库的培训和考证业务,私聊QQ646634621或微信db_bao,谢谢!

SQL Server数据库服务器CPU不能全部利用原因分析

SQL专家云深度体检里有相应的诊断,SQL Server在线的CPU核数40小于检测到的CPU核数128,说明SQL Server只使用了40个核心。

SQL Server数据库服务器CPU不能全部利用原因分析

没有SQL专家云,可以使用下面的语句查询。

分析2

从SQL Server 2012开始,企业版有两种许可证模式,基于核心和基于服务器+CAL。基于服务器+CAL许可证限制SQL Server最多能使用20个物理处理器,如果超线程已启用,这将是40个逻辑处理器。

确认数据库的版本为SQL server 2012 Enterprise Edition,也就是服务器+CAL许可证模式。

SQL Server数据库服务器CPU不能全部利用原因分析

解决3

在SQL Server安装文件中更换序列号,升级到基于核心的许可模式。

SQL Server数据库服务器CPU不能全部利用原因分析

SQL Server数据库服务器CPU不能全部利用原因分析

SQL Server数据库服务器CPU不能全部利用原因分析

重启SQL Server服务后,在SQL专家云中确认已经是基于核心的许可证模式了,并且能用使用到128个核心。

SQL Server数据库服务器CPU不能全部利用原因分析

其它情况4

如下图,在为虚拟机分配CPU时,配置了16个插槽,每个插槽内核数为1,这样SQL Server标准版只能使用到4个CPU。应该合理的配置,例如2和8或者4和4。

SQL Server数据库服务器CPU不能全部利用原因分析

SQL Server数据库服务器CPU不能全部利用原因分析

巡检脚本

麦老师的脚本也可以直接获取SQL Server的详细信息,参考:https://www.xmmup.com/sql-servershujukuxunjianjiaoben.html

SQL Server数据库服务器CPU不能全部利用原因分析

参考

https://mp.weixin.qq.com/s/Pv_wHnIlEJ8HylHSd0uhCw

标签:

头像

小麦苗

学习或考证,均可联系麦老师,请加微信db_bao或QQ646634621

您可能还喜欢...

发表回复

嘿,我是小麦,需要帮助随时找我哦
  • 18509239930
  • 个人微信

  • 麦老师QQ聊天
  • 个人邮箱
  • 点击加入QQ群
  • 个人微店

  • 回到顶部
返回顶部