修复︰ SQL Server 崩溃当 tempdb 数据库日志文件在 SQL Server 2012年或 SQL Server 2014年完整

重要说明:本文是由 Microsoft 机器翻译软件进行的翻译并可能由 Microsoft 社区通过社区翻译机构(CTF)技术进行后期编辑,或可能是由人工进行的翻译。Microsoft 同时向您提供机器翻译、人工翻译及社区后期编辑的文章,以便对我们知识库中的所有文章以多种语言提供访问。翻译的文章可能存在词汇、句法和/或语法方面的错误。Microsoft 对由于内容的误译或客户对内容的使用所导致的任何不准确、错误或损失不承担责任。

点击这里察看该文章的英文版: 2963384
症状
假定您正在使用 Microsoft SQL Server 2012年或 SQL Server 2014年。当tempdb数据库日志文件是满,SQL Server 崩溃,并且您将收到以下错误消息︰
错误︰ 9002,严重性︰ 17 日状态︰ 4。
Tempdb 数据库的事务日志已满由于 ACTIVE_TRANSACTION。
错误︰ 3314,严重性︰ 21 日状态︰ 3。
Tempdb 数据库中记录的操作的撤消,期间在日志记录 ID (135:376:442) 时出现错误。通常情况下,特定的故障记录以前为在 Windows 事件日志服务时出错。从备份中还原的数据库或文件或修复数据库。
错误︰ 3449,严重性︰ 21 日状态︰ 1。
SQL Server 必须关闭以恢复数据库 (数据库 ID 为 2)。该数据库是不可能关闭的用户数据库或系统数据库。重新启动 SQL Server。如果数据库无法恢复后再次启动,修复或还原数据库。
由于服务器关闭,SQL 跟踪已停止。跟踪 ID ="1"。这是一个信息性消息不不需要任何用户操作。

如果tempdb日志文件的大小不足以处理tempdb的工作负荷,并且日志文件的自动增长设置为禁用,则会出现此问题。如果回滚失败在tempdb中由于有限的空间,SQL Server 就会崩溃。

此修补程序可保留空间的更精确地计算日志空间不足。此修复程序还有助于避免在tempdb中的回滚失败使tempdb日志暂时增长。这些更改有助于防止服务器崩溃。
解决方案

对于 SQL Server 2014年服务包信息

要解决此问题,请获取最新的 service pack 的 Microsoft SQL Server 2014年。有关详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:

2958069 如何获取最新的 service pack 的 SQL Server 2014


有关 SQL Server 2014 Service Pack 1 (SP1) 的详细信息,请参阅 在 SQL Server 2014 Service Pack 1 修复的 bug.

SQL Server 2012年的服务包信息

若要解决此问题,请获取 Microsoft SQL Server 2012年的最新服务包。有关详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:

2755533 如何获取 SQL Server 2012 最新的服务包
状态
Microsoft 已经确认这是"适用于"一节中列出的 Microsoft 产品中的问题。

警告:本文已自动翻译

属性

文章 ID:2963384 - 上次审阅时间:08/06/2016 00:40:00 - 修订版本: 7.0

Microsoft SQL Server 2014 Enterprise, Microsoft SQL Server 2014 Developer, Microsoft SQL Server 2014 Standard, Microsoft SQL Server 2014 Express, Microsoft SQL Server 2012 Service Pack 1, Microsoft SQL Server 2012 Enterprise, Microsoft SQL Server 2012 Developer, Microsoft SQL Server 2012 Express, Microsoft SQL Server 2012 Web, Microsoft SQL Server 2012 Standard

  • kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2963384 KbMtzh
反馈