对于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错误,可以尝试一下增大该参数值。然而,千万记住,允许创建过多的线程会导致更多的开销,最终会降低性能。
【编辑推荐】