SQL体系结构之SQLServer线程管理

数据库 SQL Server
SQLServer线程由WindowsNT平均地分配线程,下文对SQLServer线程管理作了详尽的阐述,如果您对这方面感兴趣的话,不妨一看。

对于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同步复制的实现

责任编辑:段燃 来源: 互联网
相关推荐

2009-09-08 14:34:42

Linq to SQL

2009-02-05 11:07:27

Sybase SQL SybaseSQL Server

2009-06-26 15:58:28

EJB

2009-09-11 10:38:03

LINQ体系结构

2009-08-04 15:44:01

WLAN无线通信网网络管理体系网络管理结构

2009-07-15 13:46:26

Swing体系结构

2012-02-06 17:22:44

MySQL

2014-07-23 09:33:52

2020-04-15 21:43:22

JVMJavaVMware

2016-12-26 10:29:01

Spring框架结构

2010-09-25 13:38:23

Inside JVM

2010-08-16 12:54:21

ASON路由技术

2010-06-21 14:51:14

ASON路由

2009-07-10 16:07:10

TikeSwing创建MVC体系结构

2010-04-23 09:13:05

Oracle体系结构

2010-01-22 17:57:40

2009-07-09 13:52:41

Inside JVM

2013-09-02 15:53:16

Windows

2010-09-16 15:22:30

JVM体系结构

2013-08-01 11:17:20

SAP
点赞
收藏

51CTO技术栈公众号