我发现环境变量 NUMBER_OF_PROCESSORS 在我新安装的运行 Windows Server 2012 R2 Standard 的 Dell PowerEdge 740xd Gen 14 上不正确。
该机器包含 2 个 CPU - Intel Platinum Xeon 8173M。每个 CPU 包含 28 个内核,因此总共 56 个内核,但每个内核都是超线程的,因此总共有 112 个线程。我希望看到 NUMBER_OF_PROCESSORS=112 但我看到 NUMBER_OF_PROCESSORS=56 。我可以进入控制面板、系统并手动更改 NUMBER_OF_PROCESSORS 的值,但是当机器重新启动时,它又回到了 56。
请务必注意,诸如 msinfo32 和任务管理器等各种系统工具会报告正确的处理器、内核和线程数。
我在这里找到了一个相关的线程:如何生成 NUMBER_OF_PROCESSORS 环境变量?在底部,它建议在 BIOS 设置中关闭节点交错。我发现我的机器上已经关闭了 Node Interleaving,但我决定打开它,效果是 NUMBER_OF_PROCESSORS 变为 64。
在运行相同操作系统的较旧的 Dell Gen 13 机器上,我确实看到 NUMBER_OF_PROCESSORS env var 设置为 number_of_cpus x cores_per_cpu x 2 。所以这似乎是与戴尔 Gen 14 相关的问题。
NUMBER_OF_PROCESSORS
不能表示超过 64 个处理器,因为这是 64 位 Windows 的明显限制。Windows 使用处理器组来管理超过 64 个处理器,请参阅https://docs.microsoft.com/de-de/windows/win32/procthread/processor-groups
NUMBER_OF_PROCESSORS
ENV 变量只是向软件指示周围有哪些处理资源的一种方式。在禁用节点交错的情况下,操作系统会尝试通过仅指示物理内核来防止过载。在启用节点交错的情况下,它会尝试指示 SMT 线程,但由于规模太大而失败。“64”是这个“API”的硬限制。无论如何,该变量的等级很低,因为它用于批处理脚本等。有更可靠和更详细的方法来了解 CPU 设置,这是其他工具使用的。您可以尝试使用 Powershell
(Get-CimInstance Win32_ComputerSystem).NumberOfLogicalProcessors
,可能更精确。