SQL Server 监控磁盘IO错误,msdb.dbo.suspect_pages

 更新时间:2014年10月20日 14:09:56   作者:小旭  
suspect_pages 表位于 msdb 数据库中,是在 SQL Server 2005 中引入的。用于维护有关可疑页的信息的 suspect_pages

suspect_pages 表位于 msdb 数据库中,是在 SQL Server 2005 中引入的。用于维护有关可疑页的信息的 suspect_pages

数据库管理员负责管理表(主要通过删除旧的行实现)。suspect_pages 表有大小限制,如果此表已满,则不会记录新的错误。若要防止此表填满,数据库管理员或系统管理员必须通过删除行来手动清除此表中的旧条目。因此,我们建议您定期删除或存档 event_type 为已还原或已修复的行或具有旧 last_update 值的行。

若要监视对 suspect_pages 表执行的操作,可使用 Database Suspect Data Page 事件类。有时会因存在暂时性的错误向 suspect_pages 表添加行。如果正在向该表添加很多行,则 I/O 子系统可能出了问题。如果您注意到正向该表添加的行数突然增加,我们建议您检查一下 I/O 子系统是不是出现了问题。

下表显示了记录在 suspect_pages 表的 event_type 列中的错误。

错误说明 event_type

由操作系统 CRC 错误造成的 823 错误,或者校验和错误或页撕裂以外的 824 错误(例如,页 ID 错误)

1

错误的校验和

2

残缺页

3

已还原(页在标记为错误后已还原)

4

已修复(DBCC 修复了页)

5

已由 DBCC 释放

7

暂时性的错误也会记录在 suspect_pages 表中。暂时性错误的来源包含 I/O 错误(例如电缆断开连接)或暂时未通过重复校验和测试的页。

数据库引擎如何更新 suspect_pages 表

数据库引擎对 suspect_pages 表执行下列操作:

如果表未满,则每出现一个 824 错误,该表都会更新以指明出现了错误,且错误计数器也将相应递增。
如果通过修复、还原或释放操作修复后的页仍有错误,则其 number_of_errors 计数将会递增,其 last_update 列也会更新
列出的页通过还原或修复操作修复之后,该操作将更新 suspect_pages 行,以指示此页已修复 (event_type = 5) 或已还原 (event_type = 4)。

如果运行 DBCC 检查,则该检查会将所有未出错页标记为已修复 (event_type = 5) 或已释放 (event_type = 7)。

自动更新 suspect_pages 表

尝试读取数据文件中的某一页由于以下原因之一失败后,数据库镜像伙伴将更新 suspect_pages 表。

由操作系统 CRC 错误导致的 823 错误。

824 错误(像页撕裂这样的逻辑损坏)。

以下操作将自动从 suspect_pages 表中删除行。

ALTER DATABASE REMOVE FILE
DROP DATABASE
DBCC CHECKDB REPAIR_ALLOW_DATA_LOSS 更新 suspect_pages 表,以指示已释放或已修复的各页。

RESTORE 也可更新该列表。完整还原、文件还原或页面还原将页面项标记为已还原。

相关文章

  • 动态SQL中返回数值的实现代码

    动态SQL中返回数值的实现代码

    最近在做一个paypal抓取数据的程序,由于所有字段和paypal之间存在对应映射的关系,所以所有的sql语句必须得拼接传到存储过程里去执行
    2011-12-12
  • SqlServer 数据库 三大  范式

    SqlServer 数据库 三大 范式

    本文将基于三大范式原则,结合具体的实例做简要分析,对SqlServer 数据库 三大 范式相关知识感兴趣的朋友一起看看吧
    2019-11-11
  • 远程连接阿里云SqlServer 2012 数据库服务器的图文教程

    远程连接阿里云SqlServer 2012 数据库服务器的图文教程

    在使用 阿里云 上的一些产品时,遇到不少坑,安装IIS 时,遇到因买的配置过低,虚拟内存不足,而导致 IIS 总是安装失败,下面小编给大家分享远程连接阿里云SqlServer 2012 数据库服务器的图文教程,一起看看吧
    2017-09-09
  • SQL基础查询和LINQ集成化查询

    SQL基础查询和LINQ集成化查询

    本文详细讲解了SQL基础查询和LINQ集成化查询,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • drop,truncate与delete的区别

    drop,truncate与delete的区别

    这里说的delete是指不带where子句的delete语句
    2009-11-11
  • Sql Server 分组统计并合计总数及WITH ROLLUP应用

    Sql Server 分组统计并合计总数及WITH ROLLUP应用

    WITH ROLLUP 在生成包含小计和合计的报表时,ROLLUP 运算符很有用,ROLLUP 运算符生成的结果集类似于 CUBE 运算符所生成的结果集,接下来介绍Sql Server 分组统计并合计总数实现代码,感兴趣的朋友可以了解下哦
    2013-01-01
  • sql语句LEFT JOIN拼接表详解

    sql语句LEFT JOIN拼接表详解

    这篇文章主要介绍了sql语句LEFT JOIN拼接表详解,需要的朋友可以参考下
    2023-05-05
  • 异地远程访问本地SQL Server数据库

    异地远程访问本地SQL Server数据库

    数据库的重要性相信大家都有所了解,作为各种数据的电子资料夹,其中可能包含了各种信息,这篇文章就为大家介绍了如何使用cpolar内网穿透,远程连接和操作SQL Server。
    2023-04-04
  • sqlserver 聚集索引和非聚集索引实例

    sqlserver 聚集索引和非聚集索引实例

    sqlserver 聚集索引和非聚集索引实例,学习sqlserver索引的朋友可以参考下。
    2010-08-08
  • sql server不存在 sql server拒绝访问

    sql server不存在 sql server拒绝访问

    总出现“SQL Server不存在或访问被拒绝”。1,SQL Server名称或IP地址拼写有误 2,服务器端网络配置有误3,客户端网络配置有误
    2007-12-12

最新评论