暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySQL组复制监控

原创 lu9up 2024-02-25
114

前言

使用MySQL performance_schema数据库相关性能表监控组复制,这些性能表显示特定于组复制的信息。

常用的表有:

  • replication_group_members
  • replication_group_member_stats

下面详细介绍这两个表。

1 replication_group_members

该表显示了复制组成员的网络和状态信息,所示的网络地址是用于将客户端连接到组的地址。

mysql> select * from performance_schema.replication_group_members; +---------------------------+--------------------------------------+----------------+-------------+--------------+-------------+----------------+----------------------------+ | CHANNEL_NAME | MEMBER_ID | MEMBER_HOST | MEMBER_PORT | MEMBER_STATE | MEMBER_ROLE | MEMBER_VERSION | MEMBER_COMMUNICATION_STACK | +---------------------------+--------------------------------------+----------------+-------------+--------------+-------------+----------------+----------------------------+ | group_replication_applier | 13fc049e-c133-11ee-a377-000c29df1f85 | 192.168.131.20 | 3306 | ONLINE | SECONDARY | 8.0.27 | XCom | | group_replication_applier | 248563ac-c133-11ee-a387-000c29551477 | 192.168.131.30 | 3306 | ONLINE | SECONDARY | 8.0.27 | XCom | | group_replication_applier | f40395ea-c132-11ee-9249-000c29c00092 | 192.168.131.10 | 3306 | ONLINE | PRIMARY | 8.0.27 | XCom | +---------------------------+--------------------------------------+----------------+-------------+--------------+-------------+----------------+----------------------------+ 3 rows in set (0.00 sec)
复制

字段说明:

  • CHANNEL_NAME:组复制区域通道名称;
  • MEMBER_ID:成员服务器UUID。对于组中的每个成员都有不同的值。这也可以作为键,因为它对每个成员都是唯一的;
  • MEMBER_HOST:该成员的网络地址(主机名或IP地址)。从成员的主机名变量中检索。这是客户端连接到的地址,与用于内部组通信的group_replication_local_address不同;
  • MEMBER_PORT:服务器正在侦听的端口;
  • MEMBER_STATE:该成员的现状,可以是以下任何一种:
    • ONLINE:成员处于功能完备的状态;
    • RECOVERING:服务器已加入正在从中检索数据的组;
    • OFFLINE:已安装组复制插件,但尚未启动;
    • ERROR:成员在应用事务期间或在恢复阶段遇到错误,并且没有参与组的事务;
    • UNREACHABLE:故障检测进程怀疑无法联系此成员,因为组消息已超时;
  • MEMBER_ROLE:组中成员的角色,可以是PRIMARY或SECONDARY;
  • MEMBER_VERSION:成员的MySQL版本;
  • MEMBER_COMMUNICATION_STACK:用于组的通信栈,XCOM通信栈或MYSQL通信栈。这列是在MySQL 8.0.27中添加的。

2 replication_group_member_stats

此表提供了与认证过程相关的组级信息,以及复制组的每个成员接收和发起的事务的统计信息

mysql> select * from performance_schema.replication_group_member_stats\G *************************** 1. row *************************** CHANNEL_NAME: group_replication_applier VIEW_ID: 17082578864394446:3 MEMBER_ID: 13fc049e-c133-11ee-a377-000c29df1f85 COUNT_TRANSACTIONS_IN_QUEUE: 0 COUNT_TRANSACTIONS_CHECKED: 0 COUNT_CONFLICTS_DETECTED: 0 COUNT_TRANSACTIONS_ROWS_VALIDATING: 0 TRANSACTIONS_COMMITTED_ALL_MEMBERS: aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa:1-24 LAST_CONFLICT_FREE_TRANSACTION: COUNT_TRANSACTIONS_REMOTE_IN_APPLIER_QUEUE: 1 COUNT_TRANSACTIONS_REMOTE_APPLIED: 1 COUNT_TRANSACTIONS_LOCAL_PROPOSED: 0 COUNT_TRANSACTIONS_LOCAL_ROLLBACK: 0 *************************** 2. row *************************** CHANNEL_NAME: group_replication_applier VIEW_ID: 17082578864394446:3 MEMBER_ID: 248563ac-c133-11ee-a387-000c29551477 COUNT_TRANSACTIONS_IN_QUEUE: 0 COUNT_TRANSACTIONS_CHECKED: 0 COUNT_CONFLICTS_DETECTED: 0 COUNT_TRANSACTIONS_ROWS_VALIDATING: 0 TRANSACTIONS_COMMITTED_ALL_MEMBERS: aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa:1-24 LAST_CONFLICT_FREE_TRANSACTION: COUNT_TRANSACTIONS_REMOTE_IN_APPLIER_QUEUE: 1 COUNT_TRANSACTIONS_REMOTE_APPLIED: 0 COUNT_TRANSACTIONS_LOCAL_PROPOSED: 0 COUNT_TRANSACTIONS_LOCAL_ROLLBACK: 0 *************************** 3. row *************************** CHANNEL_NAME: group_replication_applier VIEW_ID: 17082578864394446:3 MEMBER_ID: f40395ea-c132-11ee-9249-000c29c00092 COUNT_TRANSACTIONS_IN_QUEUE: 0 COUNT_TRANSACTIONS_CHECKED: 0 COUNT_CONFLICTS_DETECTED: 0 COUNT_TRANSACTIONS_ROWS_VALIDATING: 0 TRANSACTIONS_COMMITTED_ALL_MEMBERS: aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa:1-24 LAST_CONFLICT_FREE_TRANSACTION: COUNT_TRANSACTIONS_REMOTE_IN_APPLIER_QUEUE: 0 COUNT_TRANSACTIONS_REMOTE_APPLIED: 3 COUNT_TRANSACTIONS_LOCAL_PROPOSED: 0 COUNT_TRANSACTIONS_LOCAL_ROLLBACK: 0 3 rows in set (0.01 sec)
复制

字段说明:

  • CHANNEL_NAME:channel名;
  • VIEW_ID:组视图id;
  • MEMBER_ID:成员uuid;
  • COUNT_TRANSACTIONS_IN_QUEUE:等待冲突检测检查的队列中的事务数;
  • COUNT_TRANSACTIONS_CHECKED:已检查冲突的事务数;
  • COUNT_CONFLICTS_DETECTED:未通过冲突检测检查的事务数;
  • COUNT_TRANSACTIONS_ROWS_VALIDATING:冲突检测数据库当前的记录数;
  • TRANSACTIONS_COMMITTED_ALL_MEMBERS:在组复制的所有成员上成功提交的事务,显示为GTID集。这是以固定60s的时间间隔更新的;
  • LAST_CONFLICT_FREE_TRANSACTION:最后一次检查的无冲突事务的GTID;
  • COUNT_TRANSACTIONS_REMOTE_IN_APPLIER_QUEUE:成员从复制组接收到等待应用的事务数;
  • COUNT_TRANSACTIONS_REMOTE_APPLIED:成员从复制组接收到已经应用的事务数;
  • COUNT_TRANSACTIONS_LOCAL_PROPOSED:由该成员发起,并发送到组的事务数;
  • COUNT_TRANSACTIONS_LOCAL_ROLLBACK:由该成员发起,,并由组回滚的事务数。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

文章被以下合辑收录

评论