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
    • 最新
    • 标签
主页 / dba / 问题 / 275895
Accepted
BeginnerDBA
BeginnerDBA
Asked: 2020-09-23 07:31:16 +0800 CST2020-09-23 07:31:16 +0800 CST 2020-09-23 07:31:16 +0800 CST

突然 SQL 服务器重新启动,挂起的任务计数增加

  • 772

我们正在尝试了解 SQL 服务器突然自行重启的问题 -

它是一个 SQL server 2012 SP4 -GDR 应用,启用了 40 个 CPU 的 HT,因此总共有 80 个逻辑处理器-

MAXDOP=8 , CTOP 5

从我们发现的错误日志中

/**********************/

BEGIN 堆栈转储

非屈服调度程序 /**********************/

仅在重新启动 SQL 时出现错误消息。也没有像检查那样创建迷你转储。

是的,当时我们有很多查询正在运行。前 3 名等待是:-

1.TranLogIO
2.CXPACKET
3.PAGELATCH SH

然而,我们也注意到SOS WORKER从系统健康 XE 收集的等待调用,我相信这不过是THREADPOOL. 因此,我进一步分析了该系统运行状况中的查询处理详细信息,并发现在未产生调度程序错误时记录了以下错误

19:46 maxworkers- 2944 workers created789 oldest pending taskwait time0 待定任务 4

19:51 maxworkers- 2944 workers created982 oldest pending taskwait time256987 待定任务 165

在 19:51,我们开始看到重启发生了。

问题是如果上述计算中仍有近 2000 个工作人员可用,为什么会有线程池等待。另外,当查询有这么多调度程序可供运行并完成对在 CXPACKETS 上等待的一堆查询的请求时,为什么那些待处理的任务计数为 165?

编辑:更新我的问题以等待 XE

SOS_MEMORY_TOPLEVELBLOCKALLOCATOR

当我阅读上面的信息时,请在这里等待https://www.sqlskills.com/help/waits/sos_memory_toplevelblockallocator/

根据博客,在 SP3 CU 中有一个修复,但使用 TF T8075:我目前使用的是 SP4-GDR 最新补丁,是否仍需要应用 TF,尽管我没有看到Failed allocate pages: FAIL_PAGE_ALLOCATION 513错误日志中的任何消息

不确定它是否有帮助-我看到总服务器内存不时下降一个演出,然后匹配到目标服务器内存,即 = 最大服务器内存 (750GB)

大多数时候总=目标=最大服务器内存。滴水只是演出而已,并不多

内存信息 = 总内存:880 GB 最大内存:750GB 最小服务器内存:130 GB 它是一个 2 节点 Windows 集群,没有共享其他 SQL 实例。资源调控器未启用

谢谢

sql-server performance
  • 1 1 个回答
  • 193 Views

1 个回答

  • Voted
  1. Best Answer
    Shanky
    2020-09-23T09:25:26+08:002020-09-23T09:25:26+08:00

    我首先要说分析 MS 人员或了解它的人中转储的最佳人选。我只想从您发布的日志中指出一些基础知识

    在 19:46 maxworkers- 2944 个工作人员创建了 789 个最旧的待处理任务等待时间 0 待处理任务 4 在 19:51 maxworkers- 2944 个工作人员创建了 982 个最旧的待处理任务等待时间 256987 待处理任务 165

    请看那个taskwait time 256987和pending task 165。这意味着调度程序已挂起,并且有 165 个任务正在等待它获取调度程序并运行。在这种情况下,MS SQL Server 无法摆脱这个挂起的调度程序场景并等待了一段时间,但它再次决定最好重新启动自己以摆脱这个挂起的调度程序场景,因此它重新启动。现在,它挂起的原因超出了我的能力范围,您发布的信息无法说明。

    另请注意,为线程分配了一个调度程序,它应该在该调度程序上运行,这就是为什么有这么多线程在这个挂起的调度程序上等待。

    • 3

相关问题

  • 死锁的主要原因是什么,可以预防吗?

  • 如何确定是否需要或需要索引

  • 我在哪里可以找到mysql慢日志?

  • 如何优化大型数据库的 mysqldump?

Sidebar

Stats

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

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve