微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

深入了解SQLServer数据库的线程与纤程

Microsoft® SQL Server™ 的错误日志可能会显示如下消息:

工作线程限制 255 已经达到。

这条消息是信息消息,并不表明系统有任何问题

sql Server 维护一个操作系统线程池,以便执行从客户端送达的成批 sql 语句。在 Microsoft Windows NT® 上,如果服务器的 lightweight pooling 配置选项设为 1,则 sql Server 不再维护线程,转而维护一个纤程池;纤程使用比线程更少的资源。使用线程池或纤程池,可以使 sql Server 在同时执行多个 sql 语句时优化处理时间分配。该池中的线程或纤程共同作为工作线程。有关更多信息,请参见线程和任务构架。

工作线程数是由服务器配置选项 max worker threads 控制的。认值为 255 而且几乎不需要更改。

当从客户端收到一批 Transact-sql 语句时,如果现有的工作线程空闲,就会分配它来执行这个批处理。如果没有空闲的现有工作线程而且工作线程数少于 max worker threads,那么就会分配一个新的工作线程。如果没有空闲的工作线程而且已经达到 max worker threads,那么新的批处理就要一直等到现有工作线程完成其当前批处理任务而空闲为止。当工作线程数达到 max worker threads 时,sql Server 显示如下消息:

工作线程限制 255 已经达到。

对所有工作线程进行分配,并不意味着 sql Server 的性能会降低。通常,新的批处理等待空闲线程只需要很短的时间。分配更多的线程可能会降低性能,因为增加的工作需要在线程之间协调资源。很多在生产状态运行的 sql Server 系统都会达到这样的状态,而且以非常高的性能级别运行。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐