SQL体系结构之SQLServer线程管理
创始人
2024-07-16 08:51:32
0

对于SQLServer线程管理,可能很多刚刚接触SQL数据库的新人都比较陌生,下面就为您详细介绍SQLServer线程管理,希望对您学习SQLServer线程管理方面能有所帮助。

复杂的应用具有多个需要同步完成的任务或处理过程。一个进程具有一个执行线程,执行应用的程序指令。我们将这个执行线程简称为线程(thread)。SQLServer使用WindowsNT操作系统的线程,有时是SQLServer的纤维(见下面的讨论),执行并发任务(微软的SQLServer桌面版不支持纤维)。线程由SQLServer启动,然后WindowsNT在SQLServer可用的多个处理器(CPU)之间平均地分配线程。可以通过企业管理器,或通过设置SQLServer的配置参数affinitymask来配置SQLServer可以使用的处理器的数量。

大多数系统通过允许SQLServer使用系统中的所有CPU,工作得***。一个线程一个时间可以在系统的一个CPU上执行。例如,具有四个CPU的系统可以并发执行四个线程。当一个线程可能处于等待I/O操作完成的状态时,另一个线程可以运行在相同的CPU上,即使在一个单CPU的系统中,也是如此。这样一来增加了可以执行的工作量。线程的管理是由WindowsNT核心代码维护的。当一个线程移出一个CPU,另一个线程移入CPU时,发生一次环境切换(contextswitch)。环境切换是一个相当耗时的操作,因为它需要在应用代码的用户模式与SQLServer线程管理代码的核心模式之间进行切换,因此,设备环境切换越少越好。为减少环境切换,SQLServer具有一个称为纤维(fibers)的新特性。

纤维是线程的子部件,缺省情况下,SQLServer并不使用纤维,但可以通过配置让SQLServer使用纤维。纤维由运行在用户模式的代码来维护,因此,切换纤维比起切换线程的操作来,并不耗时,因为不需要在核心模式与用户模式之间改变模式。纤维的调度表由SQLServer维护,而线程的调度表由WindowsNT维护;多个纤维可以运行在同一个线程上,并且纤维可以在线程中进行切换,而此时在CPU上执行的线程不用切换环境。这样大大降低了系统上的环境切换次数。如果你的系统执行了许多环境切换,试试以纤维模式运行SQLServer。要这样做,必须通过企业管理器选择该选项,或者运行sp_configure并设置lightweightpooling(轻型池)参数,它也是一个高级选项。

SQLServer维护线程池以执行SQL语句。如果设置了纤维模式,将维护纤维池而不是线程池。池中的线程或纤维,称为工作者线程(workerthread)。当在同一时间执行多条SQL语句时,工作者线程池允许SQLServer更好地分配CPU的处理时间。也可以使用配置参数maxworkerthreads(***工作者线程)配置SQLServer可用的工作者线程的数量,***值为255(可以通过企业管理器配置,或使用sp_configure存储过程配置)。

当发送一条SQL语句或一批语句给SQLServer执行时,如果池中存在空闲线程,SQLServer为该语句或批语句分配一个工作者线程;如果没有现存的空闲线程,并且尚未达到***工作者线程数,SQLServer将为这个处理启动一个新的线程;如果达到了***线程数,并且没有空闲线程,处理必须等待另一个批处理完成它的任务并释放一个线程,这种等待通常时间不会太长。如果发现一个已达到***工作者线程限制的SQLServer错误,可以尝试一下增大该参数值。然而,千万记住,允许创建过多的线程会导致更多的开销,最终会降低性能。
 

 

 

 

【编辑推荐】

带您了解SQL Server权限管理策略

SQL Server服务器角色简介

SQL Server用户帐号管理

带您了解SQL Server 2008优点

SQL Server同步复制的实现

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...