【MySQL命令】show slave status\G 超详细全面解释

    这个命令是DBA日常运维中常用来查看主从状态的命令,很多备份,监控工具也会使用到该命令监控主从状态是否正常,主从延迟,获取位点信息等。作为常用日常命令,一定要完全理解该命令的输出。今天主要结合 官方文档 和 实际输出 详细解释该命令。达到完全搞懂!

该语句提供有关副本线程的基本参数的状态信息。它需要 SUPER 或 REPLICATION SLAVE 特权。

建议使用\G语句终止符来获得更具可读性的垂直布局:

show slave status 输出以及解释

以下输出来自 MySQL 5.7.19 版本。各版本输出略有差异

mysql> show slave status\G
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send event --IO thread的状态Master_Host: 10.10.10.10         -- 主库的地址     Master_User: repl                -- 用于连接主库复制账号(这个账号是在主库上创建)Master_Port: 3300                -- 主库的端口 Connect_Retry: 10                  -- 连接重试之间的秒数(默认 60)Master_Log_File: mysql-bin.005395    -- I/O 线程当前正在读取的主库的二进制日志文件名称。Read_Master_Log_Pos: 684976832           -- I/O 线程已读取的当前主库二进制日志文件中的位点Relay_Log_File: dd-relay.000063     -- SQL线程正在读取和执行的中继日志名称Relay_Log_Pos: 684953253           -- SQL线程正在读取和执行的当前中继日志的位点Relay_Master_Log_File: mysql-bin.005395    -- SQL 线程执行的最新事件 对应在主库上的二进制日志文件名称。Slave_IO_Running: Yes                 -- IO线程是否已启动并已成功连接到主库Slave_SQL_Running: Yes                 -- SQL线程是否启动。Replicate_Do_DB:                     -- 需要复制的DBReplicate_Ignore_DB:                     -- 复制忽略的DBReplicate_Do_Table:                     -- 需要复制的表Replicate_Ignore_Table:                     -- 复制忽略的表Replicate_Wild_Do_Table:                     -- 用于指定需要复制的数据库表,支持通配符(wildcard)的形式Replicate_Wild_Ignore_Table:                     -- 用于指定需要忽略(不复制)的数据库表,同样支持通配符的形式。Last_Errno: 0                   -- Last_SQL_Errno的别名Last_Error:                     -- Last_SQL_Error的别名Skip_Counter: 0                   -- 系统变sql_slave_skip_counter 的当前值  (从库跳过的SQL数量)Exec_Master_Log_Pos: 684953080           -- SQL线程已经读取和执行过的中继日志 对应在主库二进制日志文件的位点Relay_Log_Space: 684977292           -- 所有现有中继日志文件的总大小。Until_Condition: None                -- start slave 中制定 until 语句Until_Log_File:                     -- start slave 中制定 until 语句Until_Log_Pos: 0                   -- start slave 中制定 until 语句Master_SSL_Allowed: No                  -- 是否允许与源的 SSL 连接Master_SSL_CA_File:                     -- 指定用于验证主服务器证书的证书颁发机构(CA)文件的路径Master_SSL_CA_Path:                     -- 指定用于验证主服务器证书的证书颁发机构(CA)路径的路径Master_SSL_Cert:                     -- 指定从服务器的 SSL 证书文件的路径Master_SSL_Cipher:                     -- 指定在 SSL 通信中使用的密码套件Master_SSL_Key:                     -- 指定从服务器的 SSL 私钥文件的路径Seconds_Behind_Master: 0                   -- 主从延迟
Master_SSL_Verify_Server_Cert: No                  -- 表示是否验证主服务器的 SSL 证书。Last_IO_Errno: 0                   -- 导致IO线程停止的最近一次的错误码,Errno :0 表示表示没有错误Last_IO_Error:                     -- 导致IO线程停止的最近的错误信息 。Erro为空表示没有错误 Last_SQL_Errno: 0                   -- 导致SQL线程停止的最近的错误码。Errno :0 表示没有错误 Last_SQL_Error:                     -- 导致SQL线程停止的错误信息,Erro为空表示没有错误 Replicate_Ignore_Server_Ids:                     -- 忽略复制的主库的server_idMaster_Server_Id: 181323300           -- 主库的参数server_id的值Master_UUID: 127ef593-1826-11eb-8a97-6c92bf7d39de           -- 主库参数server_uuid的值Master_Info_File: mysql.slave_master_info                        -- 在从库上存储主库信息的文件或表SQL_Delay: 0                                              -- 从库延迟主库多少秒SQL_Remaining_Delay: NULL                                           -- 当Slave_SQL_Running_State为 时 Waiting until MASTER_DELAY seconds after master executed event,该字段包含剩余延迟秒数。其他时候,该字段为 NULL。Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates -- SQL线程的运行状态Master_Retry_Count: 86400  -- 在连接丢失的情况下,从库可以尝试重新连接到主库的次数。Master_Bind:       -- Last_IO_Error_Timestamp:       -- 最近的I/O 线程发生错误的时间 格式YYMMDD hh:mm:ssLast_SQL_Error_Timestamp:       -- 最近的SQL 线程发生错误的时间 格式YYMMDD hh:mm:ssMaster_SSL_Crl:       -- 指定撤销列表 (CRL) 文件的路径,该文件包含已被撤销的 SSL 证书列表Master_SSL_Crlpath:       -- 指定撤销列表 (CRL) 文件的路径,该文件包含已被撤销的 SSL 证书列表Retrieved_Gtid_Set: 127ef593-1826-11eb-8a97-6c92bf7d39de:330411-2764671 -- 从库已经接收到的GTID的集合(I/O线程),如果GTID模式没有开启则为空。这个值是现在存在或者已经存在在relay log中的GTID集合 Executed_Gtid_Set: 127ef593-1826-11eb-8a97-6c92bf7d39de:1-2764671,
3133d0b5-8d65-11e7-9f2e-c88d83a9846a:1-12697883,
657b7d6b-8d60-11e7-b85f-6c92bf4e09e6:1-1661102840    -- 已经被写进binlog的GTID的集合(SQL线程),这个值和 系统参数 gtid_executed 相同。也和在该实例上执行 show master status 中的Executed_Gtid_Set 值相同Auto_Position: 1  -- 如果正在使用自动定位1;否则为 0。Replicate_Rewrite_DB:    -- 用于指定需要在主从复制过程中进行数据库名重写的规则。Channel_Name:    -- 正在显示的复制通道Master_TLS_Version:    -- 源上使用的 TLS 版本

重要参数的详细解释 

线程状态

Slave_IO_State

副本 I/O 线程的输出State字段 ,从库 IO 线程正在做什么:尝试连接到源、等待来自源的事件、重新连接到源等等,具体有一下状态

 

Slave_SQL_Running_State

SQL 线程的状态(类似于 Slave_IO_State

MySQL :: MySQL 5.7 Reference Manual :: 8.14.7 Replication Replica SQL Thread States

文件和位点

Master_Log_File

I/O 线程当前正在读取的主库的二进制日志文件名称

Read_Master_Log_Pos

I/O 线程已读取的当前主库二进制日志文件中的位点

Relay_Log_File

SQL线程正在读取和执行的中继日志名称

Relay_Log_Pos

SQL线程正在读取和执行的当前中继日志的位点

Relay_Master_Log_File

SQL 线程执行的最新事件 对应 在主库上的二进制日志文件名称。

Exec_Master_Log_Pos

SQL线程已经读取和执行过的中继日志 对应在主库二进制日志文件的位点

Relay_Log_Space

所有现有中继日志文件的总大小。

Slave_IO_Running

I/O 线程是否已启动并已成功连接到源。在内部,该线程的状态由以下三个值之一表示:

  • MYSQL_SLAVE_NOT_RUN。  副本 I/O 线程未运行。对于这个状态, Slave_IO_Running是 No

  • MYSQL_SLAVE_RUN_NOT_CONNECT。  副本 I/O 线程正在运行,但未连接到复制源。对于这个状态, Slave_IO_Running是 Connecting

  • MYSQL_SLAVE_RUN_CONNECT。  副本 I/O 线程正在运行,并连接到复制源。对于这个状态, Slave_IO_Running是 Yes

系统状态变量的值 Slave_running与该值相对应。

Slave_SQL_Running

SQL线程是否启动。

Replicate_Do_DBReplicate_Ignore_DB

  • Replicate_Do_DB:

    • 用于指定主从复制过程中需要复制的数据库。设置为一个数据库名,表示只复制该数据库的更新操作。可以使用逗号分隔的多个数据库名,例如 db1,db2
    • 例如,Replicate_Do_DB = db1 表示只复制 db1 数据库的更新。
  • Replicate_Ignore_DB:

    • 用于指定主从复制过程中需要忽略的数据库。设置为一个数据库名,表示不复制该数据库的更新操作。可以使用逗号分隔的多个数据库名,例如 db3,db4
    • 例如,Replicate_Ignore_DB = db3 表示不复制 db3 数据库的更新。

Replicate_Do_TableReplicate_Ignore_TableReplicate_Wild_Do_TableReplicate_Wild_Ignore_Table

  • Replicate_Wild_Do_Table:

    • 用于指定需要复制的数据库表,支持通配符(wildcard)的形式。只有匹配指定通配符的数据库表才会被复制到从服务器。
    • 例如,如果设置 Replicate_Wild_Do_Table = testdb.test_table%,则表示只有以 test_table 开头的表才会被复制。
  • Replicate_Wild_Ignore_Table:

    • 用于指定需要忽略(不复制)的数据库表,同样支持通配符的形式。匹配指定通配符的数据库表将不会被复制到从服务器。
    • 例如,如果设置 Replicate_Wild_Ignore_Table = testdb.ignore_table%,则表示以 ignore_table 开头的表将被忽略,不会被复制。

这两个字段的使用可以帮助管理员灵活地配置主从复制,选择性地复制或忽略特定的数据库表。这在一些特定的场景下非常有用,例如在主从服务器之间同步部分数据而忽略其他数据,或者限制复制的表以满足特定需求。

SHOW SLAVE STATUS 输出中,这两个字段的值会列举出匹配的数据库表。例如:

Replicate_Wild_Do_Table: testdb.test_table% 
Replicate_Wild_Ignore_Table: testdb.ignore_table%

这表示主从服务器之间的复制将仅涉及以 test_table 开头的表,并忽略以 ignore_table 开头的表。

Until_ConditionUntil_Log_FileUntil_Log_Pos

Until_Condition, Until_Log_File, 和 Until_Log_PosSHOW SLAVE STATUS 输出中用于指定主从复制停止条件的字段。

  •  Until_Condition:

    • 用于指定主从复制停止的条件。可能的值包括:
      • None: 表示不设置停止条件,正常复制。
      • Master_Pos: 表示使用日志文件和位置来指定停止的位置。
      • Relay_Log_Pos: 表示使用中继日志文件和位置来指定停止的位置。
      • Relay_Master_Log_File: 表示使用中继日志文件和主服务器的位置来指定停止的位置。
      • Executed_Gtid_Set: 表示使用 GTID 集合来指定停止的位置。
  • Until_Log_File:

    • 如果 Until_Condition 设置为 Master_PosRelay_Master_Log_File,则指定主从复制停止的日志文件名。
  • Until_Log_Pos:

    • 如果 Until_Condition 设置为 Master_PosRelay_Master_Log_File,则指定主从复制停止的日志位置。 

这些字段主要用于设置主从复制的停止条件,以便在特定的位置或 GTID 集合上停止复制。这在执行部分恢复或在特定时间点将主从复制同步到一致状态时很有用。如果设置了这些字段,主从复制将在指定条件下停止,并且不再继续同步。

Master_SSL_AllowedMaster_SSL_CA_FileMaster_SSL_CA_PathMaster_SSL_CertMaster_SSL_CipherMaster_SSL_CRL_FileMaster_SSL_CRL_PathMaster_SSL_KeyMaster_SSL_Verify_Server_Cert

  • Master_SSL_Allowed: 表示是否允许使用 SSL 进行主从复制。

    • 如果值为 No,则表示不启用 SSL 加密;
    • 如果值为 Yes,则表示启用 SSL 加密。
    • Ignored如果允许 SSL 连接但副本服务器未启用 SSL 支持

  • Master_SSL_CA_File:

    • 指定用于验证主服务器证书的证书颁发机构(CA)文件的路径。如果 SSL 启用,并且需要验证主服务器证书,则此字段会包含 CA 文件的路径。
  • Master_SSL_CA_Path:

    • 指定用于验证主服务器证书的证书颁发机构(CA)路径的路径。如果 SSL 启用,并且需要验证主服务器证书,则此字段会包含 CA 路径的路径。
  • Master_SSL_Cert:

    • 指定从服务器的 SSL 证书文件的路径。如果 SSL 启用,并且从服务器需要提供证书以进行身份验证,则此字段包含证书文件的路径。
  • Master_SSL_Cipher:

    • 指定在 SSL 通信中使用的密码套件。如果 SSL 启用,则此字段包含用于加密通信的密码套件的详细信息。
  • Master_SSL_Key:

    • 指定从服务器的 SSL 私钥文件的路径。如果 SSL 启用,并且从服务器需要提供私钥以进行身份验证,则此字段包含私钥文件的路径。

这些字段涉及到 MySQL 主从复制中使用 SSL 加密进行安全通信的设置。如果需要使用 SSL 进行主从复制,必须在主从服务器上配置相应的 SSL 证书和密钥,并确保双方配置一致。

Seconds_Behind_Master

Master_Info_File

在从库上存储主库连接信息的文件或表 ,如设置为存储在mysql.slave_master_info表中时,查询该表

SQL_Delay

延迟从库 ,从库延迟主库多少秒

SQL_Remaining_Delay

   当Slave_SQL_Running_State为 时 Waiting until MASTER_DELAY seconds after master executed event,该字段包含剩余延迟秒数。其他时候,该字段为 NULL

Retrieved_Gtid_Set

从库已经接收到的GTID的集合(I/O线程),

如果GTID模式没有开启则为空。

这个值是现在存在或者已经存在在relay log中的GTID集合

Executed_Gtid_Set

已经被写进binlog的GTID的集合(SQL线程),这个值和 系统参数 gtid_executed 相同。也和在该实例上执行 show master status 中的Executed_Gtid_Set 值相同 

Replicate_Rewrite_DB

用于指定需要在主从复制过程中进行数据库名重写的规则

Replicate_Rewrite_DBSHOW SLAVE STATUS 输出中关于主从复制设置的一个字段,用于指定主从复制中需要重写的数据库名。

  • Replicate_Rewrite_DB:
    • 用于指定需要在主从复制过程中进行数据库名重写的规则。该字段的值是一个字符串,其中包含了一组规则,用于将主服务器上的数据库名重写为从服务器上的数据库名。

这个功能主要用于在主从复制环境中更改数据库名的映射关系,从而实现不同的数据库结构。例如,如果在主服务器上有一个数据库名为 source_db,但在从服务器上想要将其重写为 destination_db,就可以使用 Replicate_Rewrite_DB 来实现这样的映射。

示例:

Replicate_Rewrite_DB = source_db -> destination_db

这表示将主服务器上的 source_db 重写为从服务器上的 destination_db

需要注意的是,使用 Replicate_Rewrite_DB 需要谨慎,确保映射关系是正确的,以免导致数据不一致。在配置时,建议详细测试并了解规则的影响。

参考 

show slave status命令输出 

https://dev.mysql.com/doc/refman/5.7/en/show-slave-status.html

https://dev.mysql.com/doc/refman/5.7/en/replica-io-thread-states.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/230090.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring01

一、Spring概述 自 2004年 4 月,Spring 1.0 版本正式发布以来,Spring 已经步入到了第 5 个大版本,也就是我们常说的 Spring 5。 Spring的基础是Spring Framework,其功能有: 1、IoC (控制反转),Spring 两大…

没错,数据库就应该跑在 k8s 里

昨天冯老板发了一篇文章探讨了为什么将数据库放入 K8S 中不是一个明智的选择。 如果是四年前有人质疑容器化数据库我觉得还可以 battle 一下,都 2023 年了还有人不能认清这个大势,我就有必要来谈谈我的看法了。 我从 K8s 0.9 版本时就开始做这件事&…

Pelee: A Real-Time Object Detection System on Mobile Devices(CVPR 2019)

文章目录 年三十AbstractIntroductionPeleeNet:一个高效的特征提取网络架构消融实验数据集不同设计选择对性能的影响 在ImageNet ILSVRC 2012上的结果真实设备上的速度 Pelee:实时目标检测系统Overview在VOC 2007上的结果不同设计选择的影响与其他框架的比较真实设备…

Linux下使用HTTP进行数据传输的代码实例

在Linux系统中,HTTP协议是一种广泛使用的应用层协议,用于在网络中传输数据。下面是一个使用Python的requests库在Linux下进行HTTP数据传输的代码实例。 python复制代码 import requests # 发送HTTP GET请求 response requests.get("h…

C++面试宝典第6题:访问数组和联合体元素

题目 阅读下面的代码段,并给出程序的输出。 (1)访问数组元素。 int a[] = {61, 62, 63, 64, 65, 66}; int *p = (int *)(&a + 1); printf("%d, %d\n", *(a + 1), *(p - 1)); (2)访问联合体元素。 union {short i;char x[2]; }a;a.x[0] = 10; a.x[1] = 1; …

YOLOv5改进 | 卷积篇 | SPD-Conv空间深度转换卷积(高效空间编码技术)

一、本文介绍 本文给大家带来的改进内容是SPD-Conv(空间深度转换卷积)技术。SPD-Conv是一种创新的空间编码技术,它通过更有效地处理图像数据来改善深度学习模型的表现。SPD-Conv的基本概念:它是一种将图像空间信息转换为深度信息…

Java_常见算法

一、常见算法 1.1 认识算法 接下来,我们认识一下什么是算法。算法其实是解决某个实际问题的过程和方法。比如百度地图给你规划路径,计算最优路径的过程就需要用到算法。再比如你在抖音上刷视频时,它会根据你的喜好给你推荐你喜欢看的视频&a…

Eolink Apikit 如何进行 Websocket 接口测试?

什么是 websocket ? WebSocket 是 HTML5 下一种新的协议(websocket协议本质上是一个基于 tcp 的协议)。 它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通讯的目的 Websocket 是一个持久化的协议。…

qemu 虚拟机

文章目录 一、参考资料二、QEMU调试参数三、QEMU 命令 一、参考资料 # 查询 qemu 包 apt list | grep qemu# 查询已安装的 qemu 包 apt list --installed | grep qemu # 查询 qemu 版本 qemu-img -V # 安装 sudo apt-get install qemu-system-arm qemu-system-mips qemu-syste…

惯性导航基础知识学习----01惯性器件相关

🌈武汉大学惯性导航课程合集是入门惯导的精品课程~ 作为导航路上的鼠鼠我,要开始学习惯性导航了~ 需要达到的要求是大致了解惯导的原理等~ 后期会陆续更新惯导相关的知识和笔记等~ 🐬 本blog为 武汉大学惯性导航课程 的记录~ 感谢团队提供的开…

verilog基础语法-计数器

概述: 计数器是FPGA开发中最常用的电路,列如通讯中记录时钟个数,跑马灯中时间记录,存储器中地址的控制等等。本节给出向上计数器,上下计数器以及双向计数器案例。 内容 1. 向上计数器 2.向下计数器 3.向上向下计数…

gitee的学习

1.git下载 下载地址:https://git-scm.com/ 2.建立远程仓库 访问:gitee.com 在此网站上创建 3.本地操作 在本地找一个任意文件,克隆git 执行命令:git clone https://gitee.com/beijing-jiaxin-times_0/test_zsx_cang_ku.git …

【算法刷题】Day19

文章目录 1. 山脉数组的峰顶索引题干:算法原理:代码: 2. 寻找峰值题干:算法原理:1. 暴力解法2. 二分查找 代码: 3. 下降路径最小和题干:算法原理:1. 状态表示2.状态转移方程3. 初始化…

vue写了这么久了您是否知道:为什么data属性是一个函数而不是一个对象?

一、实例和组件定义data的区别 vue实例的时候定义data属性既可以是一个对象,也可以是一个函数 const app new Vue({el:"#app",// 对象格式data:{foo:"foo"},// 函数格式data(){return {foo:"foo"}} })组件中定义data属性&#xff…

BM61 矩阵最长递增路径

题目 矩阵最长递增路径 给定一个 n 行 m 列矩阵 matrix ,矩阵内所有数均为非负整数。 你需要在矩阵中找到一条最长路径,使这条路径上的元素是递增的。并输出这条最长路径的长度。 这个路径必须满足以下条件: 1. 对于每个单元格,你…

风速预测(六)基于Pytorch的EMD-CNN-GRU并行模型

目录 前言 1 风速数据EMD分解与可视化 1.1 导入数据 1.2 EMD分解 2 数据集制作与预处理 2.1 先划分数据集,按照8:2划分训练集和测试集 2.2 设置滑动窗口大小为96,制作数据集 3 基于Pytorch的EMD-CNN-GRU并行模型预测 3.1 数据加载&a…

初识Dubbo学习,一文掌握Dubbo基础知识文集(3)

🏆作者简介,普修罗双战士,一直追求不断学习和成长,在技术的道路上持续探索和实践。 🏆多年互联网行业从业经验,历任核心研发工程师,项目技术负责人。 🎉欢迎 👍点赞✍评论…

Ubuntu-报错

Hadoop-Eclipse-java:耽误进度的几个报错 错误1:桥接模式与NAT模式相互切换后导致两种模式都不能访问互联网(1)具体错误:(2)错误原因:(3)解决方案&#xff1a…

Redis设计与实现之订阅与发布

目录 一、 订阅与发布 1、 频道的订阅与信息发送 2、订阅频道 3、发送信息到频道 4、 退订频道 5、模式的订阅与信息发送 ​编辑 6、 订阅模式 7、 发送信息到模式 8、 退订模式 三、订阅消息断连 1、如果订阅者断开连接了,再次连接会不会丢失之前发布的消…

股票价格预测 | Python实现基于Stacked-LSTM的股票预测模型,可预测未来(keras)

文章目录 效果一览文章概述模型描述源码设计效果一览 文章概述 以股票价格预测为例,基于Stacked-LSTM的股票预测模型(keras),可预测未来。 模型描述 LSTM 用于处理序列数据,如时间序列、文本和音频。相对于传统的RNN,LSTM更擅长捕获长期依赖关系,