AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 33493
Accepted
squillman
squillman
Asked: 2009-06-30 13:39:44 +0800 CST2009-06-30 13:39:44 +0800 CST 2009-06-30 13:39:44 +0800 CST

何时更改 64 位服务器上的 SQL 2005 最大工作线程数

  • 772

服务器环境:

  • Windows 2003 标准 R2 x64 SP2
  • SQL 2005 企业版 64 位 SP2
  • HP ProLiant BL460c G1、Xeon E5440 2.83 Ghz 处理器(四核)
  • 8 GB 内存

编辑:我还应该注意 max_workers_count 当前为 4 处理器盒的默认值 512

我们遇到了线程池死锁,我很确定这与并行性有关。死锁图与 Bart Duncan 关于Intra-Query Parallel Thread Deadlocks的帖子中的几乎相同,我没有看到死锁输出中提到锁资源,正如他帖子的警告部分中提到的那样相信这是一个并行的事情。

我正在调整看起来与这些相关的查询,但这需要一点时间(阅读“几周”)。同时,我想知道作为临时解决方法,增加线程池是否明智。

那里有任何 SQL Jocks 想帮助一个人吗?

(顺便说一句 - 由于这个问题,现在不能选择 SP3 )

sql-server sql-server-2005 deadlock threadpool
  • 2 2 个回答
  • 2340 Views

2 个回答

  • Voted
  1. Best Answer
    Jonathan Kehayias
    2009-06-30T16:04:02+08:002009-06-30T16:04:02+08:00

    如果与 Bart Duncan 的博客文章中的并行性相关,那么增加工作人员的数量根本不会影响您的死锁场景。如果它确实是一个并行死锁,那么您的快速解决方法是在您调整它时对有问题的查询进行 OPTION(MAXDOP n),并将其限制在死锁停止的位置。你可能不一定需要回到 DOP 1,我以前见过 DOP 4 修复它。

    要查看的另一件事是,如果在服务器上启用了超线程,则将其禁用。SQLOS 为 SQL Server 可用的每个逻辑 CPU 创建一个用户调度程序。使用超线程,您可以获得 8 个逻辑 CPU,这意味着您有 8 个用户调度程序。当您确实有 4 个 CPU 时,您的查询可能在 DOP 8 处运行,这可能会导致您的问题。您可以通过计算死锁 XML 图中的流程节点数来判断这是否是问题的一部分。如果您有 8 个进程节点,那么您应该尝试在服务器上禁用超线程,看看是否能解决问题。

    • 4
  2. Paul Randal
    2009-06-30T13:57:29+08:002009-06-30T13:57:29+08:00

    有关如何更改它的信息,请参见联机丛书上的此条目:max worker threads 选项,还可以从Ken Henderson 的旧博客中查看有关增加最大工作线程数的讨论。除非绝对必要,否则我会非常谨慎地这样做。

    希望这可以帮助!

    • 2

相关问题

  • 从 MySQL 迁移到 SQL Server 的最佳方法或工具

  • 如何启用与 SQL Server 实例的加密连接?

  • Vanilla Powershell 是否足以成为 Windows 和 DB 服务器管理员的语言?

  • 在 SQL Server 中,何时应将 PRIMARY Data FileGroup 拆分为辅助数据文件?

  • 如何从 SQL Server 2008 中的备份中排除索引

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve