公司网站开发费能记研发费用哪个科目,哪个app推广佣金高,网络安全厂家排名,营销网站四大要素这个命令是DBA日常运维中常用来查看主从状态的命令#xff0c;很多备份#xff0c;监控工具也会使用到该命令监控主从状态是否正常#xff0c;主从延迟#xff0c;获取位点信息等。作为常用日常命令#xff0c;一定要完全理解该命令的输出。今天主要结合 官方文档 和 实际… 这个命令是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 -- 连接重试之间的秒数默认 60Master_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 线程正在做什么尝试连接到源、等待来自源的事件、重新连接到源等等具体有一下状态 Checking master version 建立与源的连接后发生的非常短暂的状态。 Connecting to master 该线程正在尝试连接到源。 Queueing master event to the relay log 该线程已读取事件并将其复制到中继日志以便 SQL 线程可以处理它。 Reconnecting after a failed binlog dump request 该线程正在尝试重新连接到源。 Reconnecting after a failed master event read 该线程正在尝试重新连接到源。当再次建立连接时状态变为 Waiting for master to send event。 Registering slave on master 建立与源的连接后非常短暂地发生的状态。 Requesting binlog dump 建立与源的连接后发生的非常短暂的状态。该线程向源发送对其二进制日志内容的请求从请求的二进制日志文件名和位置开始。 Waiting for its turn to commit 如果启用当副本线程等待旧工作线程提交时出现的状态 slave_preserve_commit_order 。 Waiting for master to send event 该线程已连接到源并正在等待二进制日志事件到达。如果源空闲这可以持续很长时间。如果等待持续 slave_net_timeout几秒就会发生超时。此时该线程认为连接已断开并尝试重新连接。 Waiting for master update 之前的初始状态Connecting to master。 Waiting for slave mutex on exit 线程停止时短暂出现的状态。 Waiting for the slave SQL thread to free enough relay log space 您使用的是非零 relay_log_space_limit 值并且中继日志已变得足够大以至于它们的总大小超过了该值。I/O 线程正在等待直到 SQL 线程通过处理中继日志内容释放足够的空间以便它可以删除一些中继日志文件。 Waiting to reconnect after a failed binlog dump request 如果二进制日志转储请求失败由于断开连接线程在休眠时进入此状态然后尝试定期重新连接。重试之间的间隔可以使用该 CHANGE MASTER TO语句指定。 Waiting to reconnect after a failed master event read 读取时发生错误由于断开连接。CHANGE MASTER TO在尝试重新连接之前 线程将休眠语句设置的秒数 默认为 60。 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_DB, Replicate_Ignore_DB Replicate_Do_DB: 用于指定主从复制过程中需要复制的数据库。设置为一个数据库名表示只复制该数据库的更新操作。可以使用逗号分隔的多个数据库名例如 db1,db2。例如Replicate_Do_DB db1 表示只复制 db1 数据库的更新。 Replicate_Ignore_DB: 用于指定主从复制过程中需要忽略的数据库。设置为一个数据库名表示不复制该数据库的更新操作。可以使用逗号分隔的多个数据库名例如 db3,db4。例如Replicate_Ignore_DB db3 表示不复制 db3 数据库的更新。 Replicate_Do_Table, Replicate_Ignore_Table, Replicate_Wild_Do_Table, Replicate_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_Condition, Until_Log_File, Until_Log_Pos
Until_Condition, Until_Log_File, 和 Until_Log_Pos 是 SHOW SLAVE STATUS 输出中用于指定主从复制停止条件的字段。 Until_Condition: 用于指定主从复制停止的条件。可能的值包括 None: 表示不设置停止条件正常复制。Master_Pos: 表示使用日志文件和位置来指定停止的位置。Relay_Log_Pos: 表示使用中继日志文件和位置来指定停止的位置。Relay_Master_Log_File: 表示使用中继日志文件和主服务器的位置来指定停止的位置。Executed_Gtid_Set: 表示使用 GTID 集合来指定停止的位置。 Until_Log_File: 如果 Until_Condition 设置为 Master_Pos 或 Relay_Master_Log_File则指定主从复制停止的日志文件名。 Until_Log_Pos: 如果 Until_Condition 设置为 Master_Pos 或 Relay_Master_Log_File则指定主从复制停止的日志位置。
这些字段主要用于设置主从复制的停止条件以便在特定的位置或 GTID 集合上停止复制。这在执行部分恢复或在特定时间点将主从复制同步到一致状态时很有用。如果设置了这些字段主从复制将在指定条件下停止并且不再继续同步。 Master_SSL_Allowed, Master_SSL_CA_File, Master_SSL_CA_Path, Master_SSL_Cert, Master_SSL_Cipher, Master_SSL_CRL_File, Master_SSL_CRL_Path, Master_SSL_Key, Master_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_DB 是 SHOW 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