MSSQLSERVER并行度

Posted Hello Daily Notes

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MSSQLSERVER并行度相关的知识,希望对你有一定的参考价值。

Microsoft SQL Server最大并行度(MAXDOP) 配置选项控制并行计划用于执行查询的处理器的数目。此选项确定用于执行工作并行查询计划运算符的计算和线程资源。根据是否 SQL Server 设置了对称多处理 (SMP) 计算机、 非一致内存访问 (NUMA) 计算机或启用超线程的处理器上,您必须适当地配置最大并行度选项。本文讨论了可用于配置 SQL Server 的最大并行度选项,当您使用sp_configure系统存储过程的一般原则。
如果查询指定了此选项,则选项 (MAXDOP)事务处理 SQL 查询提示可以替代sp_configure值中的最大并行度选项。在 SQL Server 2000 中,重写在提示中指定的值小于或等于sp_configure值的情况下,才会生效。在 SQL Server 2005 及更高版本,该重写始终起作用。在 SQL Server 2008年和更高版本中,如果 MAXDOP 值超出值配置通过使用资源管理器中,数据库引擎所使用的资源调控器 MAXDOP 值。当您使用 MAXDOP 查询提示,与最大并行度选项一起使用的所有语义规则都适用。可以重写或影响 MAXDOP 设置其它两个选项如下所示 ︰

  注意:最大并行度配置选项可以完成不限制 SQL Server 使用的处理器数。要配置 SQL Server 使用的处理器的数目,请使用关系掩码配置选项。

未命89名

 

OLTP系统:

  在纯OLTP系统上,它的事务较短,SQL查询时间短,但是非常频繁。设置“Maximum degree of Parallelism”(MAXDOP)为1。这样做可以确保查询永远不必使用并行方式运行,并且不会导致更多的数据库引擎开销。

OLAP系统:

Data-warehousing / Reporting server: 因为查询执行时间一般较长,建议设置“Maximum degree of Parallelism”(MAXDOP)为0。

这样大多数查询将会利用并行处理,执行时间较长的查询也会受益于多处理器而提高性能。

混合系统

Mixed System (OLTP & OLAP):这样环境会是一个挑战,必须找到正确的平衡点。一般采取了非常简单的方法。设置“Maximum degree of

Parallelism”(MAXDOP)为2,这样意味着查询仍会使用并行操作但是仅利用2颗CPU。并且把“并行查询阀值”(cost threshold for parallelism)设置为较高的值,这样的话,不是所有的查询都有资格使用并行,除了那些查询成本较高的查询………

 

cost threshold for parallelism 选项可设置为 0 到 32767 之间的任何值。默认值为 5。

 

个人比较倾向于第二种(max degree of parallelism)设置的指导方针,混合系统设置max degree of parallelism,建议结合第一种推荐设置与第二种,然后结合等待事件CXPACKET的情况,作出适当的调整。不要指望一成不变的推荐设置,这样是不合理。只能根据比较大众的推荐设置,然后结合自身系统的具体情况,作出适当的调整、优化。

对于NUMA与SMP不太清楚的地方,可以参考下面资料。

传统的多核运算是使用SMP(Symmetric Multi-Processor )模式:将多个处理器与一个集中的存储器和I/O总线相连。所有处理器只能访问同一个物理存储器,因此SMP系统有时也被称为一致存储器访问(UMA)结构体系,一致性意指无论在什么时候,处理器只能为内存的每个数据保持或共享唯一一个数值。很显然,SMP的缺点是可伸缩性有限,因为在存储器和I/O接口达到饱和的时候,增加处理器并不能获得更高的性能。

NUMA模式是一种分布式存储器访问方式,处理器可以同时访问不同的存储器地址,大幅度提高并行性。 NUMA模式下,处理器被划分成多个"节点"(node), 每个节点被分配有的本地存储器空间。 所有节点中的处理器都可以访问全部的系统物理存储器,但是访问本节点内的存储器所需要的时间,比访问某些远程节点内的存储器所花的时间要少得多。

以上是关于MSSQLSERVER并行度的主要内容,如果未能解决你的问题,请参考以下文章

FlinkFlink中Key Groups与最大并行度

Flink并行度设置导致的负载倾斜 Key Groups 不均衡 计算最大并行度

Flink并行度

Flink并行度

如何通过 Parallel.ForEach 实现最大并行度并利用最大 CPU?

flink 并行度