AG排查和监控指南

1. 排查场景

如下表包含了常用排查的场景。根据被分为几个场景类型,比如Configuration,client connectivity,failover和performance。

Scenario

笔记

Scenario Type

Description

Troubleshoot AlwaysOn Availability Groups Configuration (SQL Server)

排查:AG配置

Configuration

提供了一些典型的配置AG实例发生问题的信息。比如AG被禁用,账号配置不正确,镜像endpoint不存在(SQL Server Error 1418)。网络访问不存在,join数据库失败(SQL Server Error 35250)。

Troubleshoot "Validating WSFC quorum vote configuration" warning

Configuration

当使用对话框创建AG时,收到一个警告: “The current WSFC cluster quorum vote configuration is not recommended for this availability group.”

Troubleshoot issues when creating availability group listeners

Configuration

在创建AG Listener的时候发生错误。

Troubleshoot a Failed Add-File Operation (AlwaysOn Availability Groups)

Configuration

添加文件导致secondary数据库挂起,状态变为NOT SYNCHORNIZING

Fix: Error 41009 when you try to create multiple availability groups

Configuration

创建多个AG时发生41009 错误

Cannot connect to availability group listener in a multi-subnet environment

Client Connectivity

创建了AG Listener之后,无法ping通和连接

Troubleshoot failed automatic failovers

Failover

自动故障转移不能成功完成

Troubleshoot: Availability Group Exceeded RTO

排查:AG超过RTO

Performance

自动故障转移或者计划内的手动转移之后,切换时间超过了RTO时间

Troubleshoot: Availability Group Exceeded RPO

排查:AG超过RPO

Performance

强制故障转移后,都是的数据超过了RPO。或者异步提交的replica能够承受的数据丢失超过了RPO。

Troubleshoot: Changes on the Primary Replica are not Reflected on the Secondary Replica

排查:Primary上的修改无法在Secondary体现

Performance

客户端程序可以成功的完成primary的修改,但是查询replia却没有反应。

2. 排查工具

以下工具可以用来排查,配置时或者运行时发生的问题

Tool

笔记

Description

Use the AlwaysOn Dashboard (SQL Server Management Studio)

在UI接口下,获取某个时间点的AG健康情况。

AlwaysOn Policies

被Alwayson Dashboard使用

SQL Server Error Log (AlwaysOn Availability Groups)

SQL Server错误日志(AG)

记录AG,副本,数据库,其他AG主键的状态变化,和AG的错误

CLUSTER.LOG (AlwaysOn Availability Groups)

CLUSTER.LOG(AG)

记录集群时间,包括AG资源的状态变化,SQL Server resource DDL的事件和错误。

AlwaysOn Health Diagnostics Log

AlwaysOn健康诊断日志

记录SQL Server健康诊断被报告到WSFC集群,由sp_server_diagnostics (Transact-SQL)产生

Dynamic Management Views and System Catalog Views (AlwaysOn Availability Groups)

DMV和系统目录视图

报告AG的信息,比如配置,健康状况,性能问题

AlwaysOn Extended Events

AG扩展事件

提供了详细AG信息用来诊断,分析起因

AlwaysOn Wait Types

AlwaysOn等待类型

提供了AG特定的等待信息,用来调整性能

AlwaysOn Performance Counters

监控AG的活动,反馈到系统监视器,用来调优,具体可以看 SQL Server, Availability Replica 和 SQL Server, Database Replica.

AlwaysOn Ring Buffers

AlwaysOn Ring Buffers

记录SQL Server系统内部争端的警告,用来debug和AG有关的问题。

3. 监控AG

理想的排查时间是在故障转移之前。这个可以通过监控性能值,在超过SLA之前发送告警。比如同步secnodary副本有性能问题,因为预计failover时间增加。AG是高可用和灾难恢复解决访问,最重要的性能指标是切换时间,会影响RTO,灾难导致的数据丢失会影响RPO。

以下表文章用来监控AG的健康状况:

Topic

笔记

Description

Monitor Performance for AlwaysOn Availability Groups

监控AG性能

描述AG数据同步,阀值控制,和一些有用的值用来监控AG,还有如何收集RTO,RPO的值。

Monitoring of Availability Groups (SQL Server)

提供一些AG监控工具

The AlwaysOn Health Model Part 1 -- Health Model Architecture

健康模型 Part 1——概述

提供一个Alwayson健康模型的概述

The AlwaysOn Health Model Part 2 -- Extending the Health Model

健康模型 Part 2 ——扩展

如何用户定制Alwayson监控模型和用户定义Alwayson Dashboard,来显示额外的信息。

Monitoring AlwaysOn Health with PowerShell - Part 1: Basic Cmdlet Overview

使用Powershell监控AlwayOn健康

提供一些基本的Alwayson Powershell命令。用来监控AG的健康状况。

Monitoring AlwaysOn Health with PowerShell - Part 2: Advanced Cmdlet Usage

使用Powershell监控AlwayOn健康

提供一些高级的Alwayson Powershell命令。用来监控AG的健康状况。

Monitoring AlwaysOn Health with PowerShell - Part 3 : A Simple Monitoring Application

使用Powershell监控AlwayOn健康

显示如何使用城区监控AG。

Monitoring AlwaysOn Health with PowerShell - Part 4 : Integration with SQL Server Agent

使用Powershell监控AlwayOn健康

如何使用SQL Server Agent集成监控AG,并且在出问题的时候通知。

[AlwaysOn Availability Groups]AG排查和监控指南的更多相关文章

  1. [AlwaysOn Availability Groups]AG扩展事件

    AG扩展事件 SQL Server 2012定义了一些关于AlwaysOn的扩展事件.你可以监控这些扩展事件来帮助诊断AG的根本问题.你也可以使用以下语句查看扩展事件: SELECT * FROM s ...

  2. [AlwaysOn Availability Groups]排查:AG配置

    排查AG配置 本文主要用来帮助排查在AG配置时出现的问题,包括,AG功能被禁用,账号配置不正确,数据库镜像endpoint不存在,endpoint不能访问. Section Description A ...

  3. [AlwaysOn Availability Groups]DMV和系统目录视图

    DMV和系统目录视图 这里主要介绍AlwaysON的动态管理视图,可以用来监控和排查你的AG. 在AlwaysOn Dashboard,你可以简单的配置的GUI显示很多可用副本的DMV和可用数据库通过 ...

  4. [SQL in Azure] Tutorial: AlwaysOn Availability Groups in Azure (GUI)

    http://msdn.microsoft.com/en-us/library/azure/dn249504.aspx Tutorial: AlwaysOn Availability Groups i ...

  5. [AlwaysOn Availability Groups]CLUSTER.LOG(AG)

    CLUSTER.LOG(AG) 作为故障转移资源,在SQL Server和windows故障转移集群服务的资源DLL(hadrres.dll)之间有额外的内部交流,DLL无法被SQL Server监控 ...

  6. [AlwaysOn Availability Groups]AlwaysOn等待类型

    AlwaysOn等待类型 当排查AlwaysOn延迟,等待统计信息可以在DMV中查看累计的AlwaysOn等待类型. 查看AlwaysOn等待类型 SELECT * FROM sys.dm_os_wa ...

  7. [AlwaysOn Availability Groups]监控AG性能

    监控AG性能 AG的性能的性能方面,在关键任务数据库上进行语句级维护性能是很重要的.理解AG如何传输日志到secondary副本对评估RTO和RPO,表明AG是否性能不好. 1. 数据同步步骤 为了评 ...

  8. [AlwaysOn Availability Groups]排查:AG超过RPO

    排查:AG超过RPO 在异步提交的secondary上执行了切换,你可能会发现数据的丢失大于RPO,或者在计算可以忍受的数据都是超过了RPO. 1.通常原因 1.网络延迟太高,网络吞吐量太低,导致Pr ...

  9. [AlwaysOn Availability Groups]排查:AG超过RTO

    排查:AG超过RTO 自动故障转移或者手动转移之后,没有数据都是,你可能会发现切换时间超过了你的RTO.或者当你评估切换时间同步提交secondary副本,发现超过了你的RTO. 1. 通常原因 通常 ...

随机推荐

  1. 自定义Sublime Text的图标

    sublime text很赞,windows上最接近mac逼格的轻量编辑器,对于我这样比较喜欢格调的人来说,简直不二之选啊. 美中不足的是,看久了觉得它的图标似乎不是很上心.现在都流行扁平化了而它还停 ...

  2. 基于Hexo和Github搭建博客

    搭建自己的个人博客. 准备工作 确保电脑需要已下载安装node和npm.查看安装是否成功,windows只需在命令行输入以下两条命令即可. 1 2 $ node -v $ npm -v 安装hexo ...

  3. 解析大型.NET ERP系统 单据标准(新增,修改,删除,复制,打印)功能程序设计

    ERP系统的单据具备标准的功能,这里的单据可翻译为Bill,Document,Entry,具备相似的工具条操作界面.通过设计可复用的基类,子类只需要继承基类窗体即可完成单据功能的程序设计.先看标准的销 ...

  4. 【.NET深呼吸】动态类型(扩充篇)

    前面两文中,老周已向大家介绍了关于动态类型对象的两种级别的使用方案,本篇呢,老周再讲一个自定义动态类型的例子. 前面给大家演示的例子中,动态类型中包装的是字典类型来存储数据的,这一次咱们换一种风味,老 ...

  5. Hadoop的数据管理

    Hadoop的数据管理,主要包括Hadoop的分布式文件系统HDFS.分布式数据库HBase和数据仓库工具Hive的数据管理. 1.HDFS的数据管理 HDFS是分布式计算的存储基石,Hadoop分布 ...

  6. 神秘的 shadow-dom 浅析

    说到 shadow-dom 可能很多人会很陌生.但是其实我们肯定碰到过,本文主要想简单介绍下 shadow-dom.下面直接进入正文. shadow-dom 是什么 顾名思义, shadow-dom, ...

  7. UploadFile控件,提交图片后,页面预览显示刚刚提交的图片

    最近在用asp.net来写一个新闻系统后台,然后由于不用用网上的flash插件来上传图片什么的,我就用asp.net的控件来写,但是控件总归有一些用的不够灵活的地方.这次测试提出,文章在修改的时候,需 ...

  8. centos下MYSQL 没有ROOT用户的解决方法。

    SbTest for using sysbench creating scritps: sysbench --test=oltp --oltp-table-size=100000 --mysql-db ...

  9. PID控制

    PID解释: 位置式:      可以看出,比例部分只与当前的偏差有关,而积分部分则是系统过去所有偏差的累积.位置式PI调节器的结构清晰,P和I两部分作用分明,参数调整简单明了.但直观上看,要计算第拍 ...

  10. java中异常抛出后代码还会继续执行吗

    今天遇到一个问题,在下面的代码中,当抛出运行时异常后,后面的代码还会执行吗,是否需要在异常后面加上return语句呢? public void add(int index, E element){ i ...