SQL Server First Responder Kit 中的 AG 副本延迟检测功能增强
2025-06-22 18:36:23作者:江焘钦
在 SQL Server 的高可用性解决方案中,可用性组(AG)是最常用的技术之一。然而,当 AG 副本出现同步延迟时,管理员往往难以及时发现,这可能导致故障转移时数据丢失或性能问题。
问题背景
SQL Server First Responder Kit 是一套广受欢迎的开源诊断工具集,其中的 sp_Blitz 和 sp_BlitzFirst 存储过程用于快速识别 SQL Server 的健康状况。在之前的版本中,对于 AG 副本同步状态的检测不够全面,特别是当副本出现轻微但持续的延迟时,管理员可能无法及时获得警告。
技术实现
最新版本中增加了对 AG 副本延迟的主动检测功能,当发现任何副本的同步延迟超过60秒时,会生成明确的警告信息。这一功能基于以下关键 DMV(动态管理视图)查询实现:
SELECT
ag.name AS [AG Name],
ar.replica_server_name AS [Replica Name],
drs.database_name,
drs.redo_queue_size AS [Redo Queue Size (KB)],
drs.log_send_queue_size AS [Log Send Queue Size (KB)],
drs.log_send_rate AS [Log Send Rate (KB/sec)],
drs.redo_rate AS [Redo Rate (KB/sec)],
ps.last_commit_time AS [Primary Commit Time],
drs.last_commit_time AS [Replica Commit Time],
DATEDIFF(SECOND, drs.last_commit_time, ps.last_commit_time) AS [Seconds Behind]
FROM
sys.dm_hadr_database_replica_states AS drs
JOIN
sys.availability_replicas AS ar
ON drs.replica_id = ar.replica_id
JOIN
sys.availability_groups AS ag
ON ar.group_id = ag.group_id
JOIN
sys.dm_hadr_database_replica_states AS ps
ON drs.group_id = ps.group_id
AND drs.database_id = ps.database_id
AND ps.is_local = 1 -- 主副本
WHERE
drs.is_local = 0 -- 从副本
ORDER BY
[Seconds Behind] DESC;
技术细节解析
-
数据来源:查询主要利用了三个关键系统视图:
- sys.dm_hadr_database_replica_states:提供每个数据库副本的详细状态信息
- sys.availability_replicas:包含可用性组中每个副本的配置信息
- sys.availability_groups:记录可用性组的基本信息
-
关键指标:
- Redo Queue Size:待重做的日志量(KB)
- Log Send Queue Size:待发送的日志量(KB)
- Log Send Rate:日志发送速率(KB/秒)
- Redo Rate:日志重做速率(KB/秒)
- Seconds Behind:副本落后主副本的秒数
-
阈值设置:60秒的阈值是一个经验值,既不会对短暂网络波动过于敏感,又能及时发现潜在问题。
实际应用价值
这一增强功能为DBA提供了以下优势:
- 主动预警:在副本延迟达到可接受上限时及时提醒,避免问题扩大
- 全面视图:不仅显示延迟时间,还提供相关的队列大小和处理速率
- 易于集成:作为SQL Server First Responder Kit的一部分,可以无缝集成到现有的监控体系中
- 性能影响小:基于DMV的查询对系统性能影响极小
最佳实践建议
- 定期运行sp_Blitz检查,特别是在维护窗口前后
- 对于关键业务系统,可以考虑将阈值调整为更严格的值(如30秒)
- 当收到警告时,应结合Log Send Rate和Redo Rate分析瓶颈所在
- 长期延迟可能表明网络带宽不足或从副本负载过高
这一功能的加入使得SQL Server First Responder Kit在高可用性环境中的诊断能力更加全面,帮助DBA更早发现并解决AG同步问题,确保业务连续性。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
503
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
286
暂无简介
Dart
905
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108