MSSQL中的幽灵数据删除进程、虚影清除进程(ghost cleanup)

0    166    1

Tags:

👉 本文共约1877个字,系统预计阅读时间或需8分钟。

简介

虚影清除进程是一个单线程后台进程,用于删除页面中已标记为删除的记录。

虚影记录

从索引页的叶级别删除的记录不会从页面中物理删除,而会将该记录标记为“待删除”或“虚影”。 这意味着该行保留在页面上,但行标题中的发生了一些变化,表明该行实际上是虚影。 这是为了在删除操作期间优化性能。 虚影对于行级锁定和快照隔离(此时需要维护旧版的行)都是必需的。

虚影记录清除任务

标记为删除或虚影的记录由后台虚影清除进程清除。 此后台进程在删除事务提交后的某个时间运行,并从页面上物理删除虚影记录。 虚影清除进程会以一个时间间隔自动运行(SQL Server 2012+ 每 5 秒钟运行一次、SQL Server 2008/2008R2 每 10 秒钟运行一次),并检查是否有任何页面已标记有虚影记录。 如果找到,它将转到相应位置并删除标记为删除或虚影的记录,每次执行时最多处理 10 个页面。

记录被虚影化时,会将数据库标记为“具有虚影条目”,虚影清除进程只会扫描这些数据库。 删除所有虚影记录后,虚影清除进程也会将数据库标记为“没有虚影记录”,并在下次运行时跳过该数据库。 该进程还会跳过它无法加上共享锁的所有数据库,并在下次运行时再次尝试。

以下查询可以确定单个数据库中存在的虚影记录数。

禁用虚影清除

在具有大量删除记录的高负载系统上,由于页面保留在缓冲池中并生成 IO,虚影清除进程可能会导致性能问题。 在这种情况下,可使用跟踪标志 661 来禁用该进程。 但是,禁用该进程会对性能产生影响。

禁用虚影清除进程可能会导致数据库不必要地增大,并可能导致性能问题。 由于虚影清除进程会删除标记为“虚影”的记录,因此禁用该进程会将这些记录留在页面上,从而阻止 SQL Server 重用此空间。 这转而会强制 SQL Server 将数据添加到新页面,导致数据库文件膨胀,还可能导致页面拆分。 在创建执行计划和执行扫描操作时,页面拆分会导致性能问题。

一旦禁用虚影清除进程,需采取一些行动来删除虚影记录。 一种选择是执行索引重新生成,这将在页面上移动数据。 另一种选择是手动运行 sp_clean_db_free_space(清除所有数据库数据文件)或 sp_clean_db_file_free_space(清除单个数据库数据文件),这将删除虚影记录。

本人提供Oracle(OCP、OCM)、MySQL(OCP)、PostgreSQL(PGCA、PGCE、PGCM)等数据库的培训和考证业务,私聊QQ646634621或微信dbaup66,谢谢!
AiDBA后续精彩内容已被站长无情隐藏,请输入验证码解锁本文!
验证码:
获取验证码: 请先关注本站微信公众号,然后回复“验证码”,获取验证码。在微信里搜索“AiDBA”或者“dbaup6”或者微信扫描右侧二维码都可以关注本站微信公众号。

标签:

Avatar photo

小麦苗

学习或考证,均可联系麦老师,请加微信db_bao或QQ646634621

您可能还喜欢...

发表回复