背景

 

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

 

1.现象

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

sql server openjson 多线程 sqlserver线程数_Server


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

sql server openjson 多线程 sqlserver线程数_服务器_02

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

sql server openjson 多线程 sqlserver线程数_服务器_03

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

sql server openjson 多线程 sqlserver线程数_服务器_04

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

sql server openjson 多线程 sqlserver线程数_服务器_05

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

--CPU总数    
SELECT
  cpu_count
FROM
  sys.dm_os_sys_info



--在线CPU数  
SELECT
  COUNT(*)
FROM
  sys.dm_os_schedulers
WHERE
  is_online = 1
  AND status = 'VISIBLE ONLINE'

2.分析

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

确认数据库的版本为SQLserver2012Ente