排查:AG超过RTO

自动故障转移或者手动转移之后,没有数据都是,你可能会发现切换时间超过了你的RTO。或者当你评估切换时间同步提交secondary副本,发现超过了你的RTO。

1. 通常原因

通常引起故障转移超过RTO的原因:

1.报表负荷堵塞了Redo线程。

2.因为资源争用,Redo线程被落下。

2. 报表负荷堵塞了Redo线程

Redo线程在secondary副本被一个只读长运行语句堵塞。

原因:
在secondary副本,只读查询获得Sch-s锁,这些sch-s锁会堵塞redo线程获得sch-m锁执行DDL修改。被堵塞的redo线程不能应用log记录,直到被释放。一旦被释放,可以执行redo。并且允许执行随后的undo和failover过程执行。

诊断和解决:
当redo线程被堵塞,扩展时间会生产,sqlserver.lock_redo_blocked。另外你可以查询sys.dm_exec_request,查看那个会话堵塞了redo。

select session_id, command, blocking_session_id,
wait_time, wait_type, wait_resource

from sys.dm_exec_requests where
command = 'DB STARTUP'

可以通过kill会话,强制释放锁。

3. 因为资源争用,Redo线程被落下。

大报表行为降低了secondary的性能,导致redo线程被落下

原因:
当应用log记录,redo线程读取log记录,并且应用这些log访问数据page。Page访问可能造成IO瓶颈,如果page不在内存中。如果还有IO密集型的负荷,照成IO资源争用,会降低redo线程的性能。

诊断和解决:
你可以通过DMV查看被落下了多少,通过对比last_redone_lsn和last_received_lsn

select recovery_lsn, truncation_lsn, last_hardened_lsn, last_received_lsn,

last_redone_lsn,
last_redone_time

from sys.dm_hadr_database_replica_states

如果redo线程被真的落下了,就需要研究secondary上的性能问题,是否有IO争用问题。可以通过Resource Governor 来限制其他会话的资源使用

最新文章

  1. linux常见命令总结
  2. gulp整理
  3. [转]Python yield 使用浅析
  4. boost解析json(2)
  5. Java基础之创建窗口——使窗口在屏幕居中(TryWindow2/TryWindow3)
  6. css换行和超出隐藏
  7. 转:loadruner报错:Step download timeout(120 seconds)的一个解决方法
  8. input【type="checkbox"】标签与字体对齐
  9. 【leetcode】经典算法题-Counting Bits
  10. windows环境中JDK环境变量配置
  11. npm -g -D -s的区别
  12. webpack踩坑--webpack 2.x升级至4.x
  13. Typescript 学习笔记三:函数
  14. 天融信资料下载官方FTP服务器
  15. java的MVC与C#
  16. 基于alpine用dockerfile创建的ssh镜像
  17. C语言中求字符串的长度
  18. [AGC003F] Fraction of Fractal 矩阵快速幂
  19. ngnix学习视频
  20. Node 中的 stream (流)

热门文章

  1. .net程序部署(mono方式)
  2. Winform分页控件
  3. 一句jQuery代码返回顶部
  4. SqlServer -- char与varchar、nchar、N
  5. IOS开发的基础知识
  6. WPF数据编辑的提交与撤销
  7. Python 3.4 Library setup
  8. 在PHP语言中使用JSON和将json还原成数组
  9. 当shiro不进入自定义realm的权限认证方法时
  10. 在window下配置laravel开发环境