更多信息
回滚可能需要很长时间(如长时间运行的事务)的原因有多种,例如事务日志文件中的大量 VLFs、速度较慢的 i/o 等。 为了验证本文所述的问题是否是缓慢回退的根本原因,我们建议使用以下技术监视回退操作的进度:
从 sys.dm_exec_requests中,标识其命令设置为 "已终止/回滚" 的 session_id,并确保会话将累积 IO 和 CPU 时间来指示进度。 如果 IO 未更改,则可能表明你遇到了本文中所述的问题。
查询 sys.dm_tran_database_transactions 使用如下查询标识回退的当前状态:
选择 getdate ()作为 CurrentTime、database_transaction_next_undo_lsn、database_transaction_begin_lsn、t.transaction_id、database_transaction_begin_time、database_transaction_log_record_count、db_name (t.database_id)
从 sys.dm_tran_database_transactions t
加入 sys.dm_exec_requests s
在 t.transaction_id = s.transaction_id
其中 t.database_id = db_id ('
注意:
在上述查询中,
database_transaction_next_undo_lsn是要撤消的下一条记录的 lsn。 database_transaction_begin_lsn是事务日志中事务的开始记录的 lsn。
database_transaction_next_undo_lsn应减少此查询的每个快照。 当 database_transaction_next_undo_lsn达到 database_transaction_begin_lsn 时,回退将成功完成。
此处的目标是在预先确定的间隔内拍摄上一个查询的几个快照,然后使用该间隔内 database_transaction_next_undo_lsn中处理的 LSNs 的增量,并推断所花费的时间,以便估计 database_transaction_next_undo_lsn达到 database_transaction_begin_lsn所需的时间。
如果回滚在每个快照之间以相当的速率前进,我们建议允许回退自行完成,而无需重新启动 SQL Server 实例。
有关长时间运行的恢复的详细信息,请参阅以下文章:
状态
Microsoft 已确认这是在“适用范围”部分中列出的 Microsoft 产品存在的问题。
参考
了解 Microsoft 用于描述软件更新的 术语。