Error: 7884, Severity: 20, State: 1

原创 2014年11月21日 16:31:57


背景:

         程序异常中断“TCPProvider, error: 0 - An existing connection was forcibly closed by the remotehost.”,手工执行查询没有问题,不过执行时间要几十秒。Trace程序的执行,发现要数十分钟,经了解,原因在于程序使用了SqlDataReader读取数据,并且在读取的过程中进行了一系列数据处理,导致整个完成过程时间变得很长。由此怀疑是网络不稳定之类的因素导致处理过程中连接中断,协调之后改为DataTable做一次性数据加载,程序调整之后,出现故障的频繁大大降低,但无法完全杜绝。

         进一步检查,发现在SQLServer日志中,有如下错误:

Error: 7884, Severity:20, State: 1. (Params:). The error is printed in terse mode because there waserror during formatting. Tracing, ETW, notifications etc are skipped. 

         这个错误与sys.messages中的标准描述不一样,在网上搜索没有找到合适的解决方案。

排查:

把查询的表专门导到一台服务器做测试,最终发现与一个nvarchar(max)列有关,随后想起在不久前,因为Logreader出问题,把出问题的数据列从ntext改为nvarchar(max),于是专门测试这个修改,最终确定问题是这个修改导致。

text/ntext列可能会导致logreaderagent出问题,这个遇到多次了,但没有明确的重现故障的方法,所以不讨论这个)

故障重现:

使用下面的T-SQL创建测试表,数据,并修改ntext列为nvarchar(max)

-- ======================================================

-- 创建测试表

-- ======================================================

USE tempdb;

GO

IF OBJECT_ID(N'dbo.tb_test', 'U') IS NOT NULL

     DROPTABLE dbo.tb_test;

GO

CREATE TABLEdbo.tb_test(

     id intIDENTITY PRIMARYKEY,

     Code varchar(50),

     Datedatetime,

     Value ntext

);

GO

INSERT dbo.tb_test

SELECT TOP(10000)

     Code =RIGHT(10000000000 +ABS(CHECKSUM(NEWID())) % (1000 * 2 ), 20),

     Date= DATEADD(DAY, CHECKSUM(NEWID()) % 100 , GETDATE() ),

     Value =CONVERT(char(36), NEWID() )

FROM sys.all_columns A WITH(NOLOCK)

     ,sys.all_columns B WITH(NOLOCK)

;

GO

 

-- ======================================================

-- 修改 ntext 字段类型为 nvarchar(max)

-- ======================================================

ALTER TABLEdbo.tb_test ALTERCOLUMN Value nvarchar(max);

GO

 

编写程序,查询数据,并且在查询完成前更改数据,这里用 PowherShell 做测试

# 连接字符串

$ConnectionString = "Data Source=127.0.0.1;InitialCatalog=tempdb;Integrated Security=SSPI"

 

# 打开连接

$SqlCnnectionQuery = New-Object System.Data.SqlClient.SqlConnection -ArgumentList $ConnectionString

$SqlCnnectionQuery.Open()

 

# 查询数据

$SqlCommandQuery = New-Object System.Data.SQLClient.SQLCommand

$SqlCommandQuery.Connection = $SqlCnnectionQuery

$SqlCommandQuery.CommandText = "SELECT * FROM( SELECT value, row_id = ROW_NUMBER()OVER( PARTITION BY Code ORDER BY date DESC) FROM dbo.tb_test WITH(NOLOCK) )DATAWHERE row_id = 1"

$SqlReader = $SqlCommandQuery.ExecuteReader()

 

# 修改数据

$SqlCnnectionUpdate = New-Object System.Data.SqlClient.SqlConnection -ArgumentList $ConnectionString

$SqlCnnectionUpdate.Open()

$SqlCommandUpdate = New-Object System.Data.SQLClient.SQLCommand

$SqlCommandUpdate.Connection = $SqlCnnectionUpdate

$SqlCommandUpdate.CommandText = "UPDATE top(1000) dbo.tb_test SET Value =CONVERT(char(36), NEWID() ) WHERE id IN( SELECT TOP 1000 id FROM dbo.tb_testORDER BY id DESC )"

$UpdateRows = $SqlCommandUpdate.ExecuteNonQuery()

$SqlCnnectionUpdate.Close()

"Update $UpdateRows rows."

 

#读取查询数据

#读取过程中会出现错误

#   (SQL 2008 R2 SP2) TCP Provider, error: 0 - Anexisting connection was forcibly closed by the remote host.

#   (SQL 2008 R2 SP3) TCP Provider, error: 0 - The specifiednetwork name is no longer available.

At line:1 char:22

"Read query data...."

$ReadRows=0

While($SqlReader.Read()) {$ReadRows+=1}

"Read $ReadRows rows."

 

# 关闭连接

$SqlReader.Close()

$SqlCnnectionQuery.Close()

 

故障处理:

对于修改了数据类型的列,将数据重新更新就可以解决 问题(UPDATE SET 修改的列=修改的列)

这个问题测试了 SQL Server2008 2014,都存在问题。其中 SQL Server 2008 R2 SP3中测试,SQL Server日志中的错误信息有所不同,是:

Error: 7886, Severity: 20, State: 2.

A read operation on a large object failedwhile sending data to the client. A common cause for this is if the applicationis running in READ UNCOMMITTED isolation level. This connection will beterminated.

无语,遭遇: Error: 605, Severity: 21, State: 3

最近遇到一个严重错误Error: 605, Severity: 21, State: 3.Attempt to fetch logical page (1:xxxxx) in database 2 f...
  • zjcxc
  • zjcxc
  • 2013-12-09 17:10:42
  • 9191

持续集成之Jenkins+Gitlab简介 [一]

持续集成之Jenkins+Gitlab简介 [一]标签(空格分隔): Jenkins持续集成概念持续集成Continuous Integration 持续交付Continuous Delivery 持...
  • abcdocker
  • abcdocker
  • 2016-12-23 15:18:54
  • 3435

Centos6.3下jdk+tomcat安装部署

最近一直在学习LINUX下的脚本语言,好久没有更新应用了,刚好群里有人问我关于tomcat的安装配置问题,这不就忙里偷闲,整理了篇tomcat的文档,供大家分享。安装部署:系统环境:centos6.3...
  • xiaohui2015
  • xiaohui2015
  • 2018-03-22 09:26:32
  • 10

sybase Error: 624, Severity: 21, State: 1

数据库版本: Adaptive Server Enterprise/12.5.0.3/EBF 11449 ESD#4/P/NT (IX86)/OS 4.0/rel12503/         1939...
  • laizemu
  • laizemu
  • 2009-10-16 21:32:00
  • 5347

[转]Quick Tip: Error: 18456, Severity: 14, State: 38.

原文链接:http://www.ssistalk.com/2011/05/06/quick-tip-error-18456-severity-14-state-38/When trying to in...
  • wstoneh01
  • wstoneh01
  • 2016-07-28 08:22:19
  • 717

富文本编辑+fs操作文件+Buffer练习(头像上传功能)

富文本编辑内容引用=>1.UEditor是由百度web前端研发部开发所见即所得富文本web编辑器下载的文件 引入目录文件进来:文件上传功能引用文件: require(‘../ueditor/’);...
  • qq_26766283
  • qq_26766283
  • 2017-06-06 00:42:35
  • 7387

codeforces-3A-Shortest path of the king( 棋盘最短路径 + 贪心 )

A. Shortest path of the king time limit per test 1 second memory limit per test 64 megab...
  • qq_16542775
  • qq_16542775
  • 2016-06-03 15:48:58
  • 590

dll中使用Cstring类型,调用出现Error LNK2001错误

纪念我的第一篇博文。 出处:BOE:OLED监测系统V2。 关键字:Dll,MFC,Cstring,ATL,Error LNK2001 分析:         在dll中使用了Cstring类型...
  • baidu_37503452
  • baidu_37503452
  • 2017-06-23 17:31:28
  • 275

对LR回放中highest severity level was"ERROR"的第二个解决方法

错误:ction.c(34): Error -27727: Step download timeout (120 seconds) has expired when downloading resou...
  • zeeslo
  • zeeslo
  • 2006-10-23 23:19:00
  • 6090

SpringMVC+easyui显示数据

最近做毕业设计,想用easyui,先学习一下CRUD,今天先弄了个表格显示数据库的数据。jsp页面还有很多其它元素,我就不贴上去了。我显示数据的JSP为/WebContent/WEB-INF/view...
  • yang362046076
  • yang362046076
  • 2015-03-13 18:32:11
  • 22130
收藏助手
不良信息举报
您举报文章:Error: 7884, Severity: 20, State: 1
举报原因:
原因补充:

(最多只允许输入30个字)