show slave status中的log_file / log_pos

在MySQL的master-slave或dual master的架构中,我们经常使用show
slave status命令来查看复制状态。

这里涉及几个重要的日志文件和位置:

  • Master_Log_File,Read_Master_Log_Pos: 记录了IO
    thread读到的当前master binlog文件和位置,对应master的binlog文件和位置。

  • Relay_Log_File,Relay_Log_Pos: 记录了SQL
    thread执行到relay log的那个文件和位置,对应的是slave上的relay log文件和位置。

  • Relay_Master_Log_File,Exec_Master_Log_Pos:
    记录的是SQL thread执行到master binlog的文件和位置,对应的master上binlog的文件和位置。

binlog的event语句开始位置就是二进制binlog文件的字节偏移位置。而且根据上一个event的end_log_pos可以找到下一个event开始的位置,如下图所示。

下图是一个mysqlbinlog解析普通的relay
log文件出来的文本文件:

relay
log和binlog记录方式基本相同,最大的不同就是end_log_pos记录的是master的binlog文件中event的位置,而不是relay
log自己event的位置。如图所示,上一个event的end_log_pos和下一个relay log
event开始的位置不一样。为什么需要这样设置?就是为了方便找到master binlog的位置。在slave上,记录relay log
下一个event的开始偏移意义不大,但是如果记录了master binlog的偏移量,我们就可以在SQL
thread中明确我们执行到master的某个binlog的哪个位置了。每个relay log开头都有这么一个rotate
event,也就是当前master的binlog文件名。

  • IO thread
    把所有从master读到的binlog记录到本地的binlog中,所以relay log的最后一个event的end
    log_pos就是Read_Master_Log_Pos

  • SQL thread
    按照transaction来执行,所以Exec_Master_Log_Pos对应relay
    log中最后一个事务event的end_log_pos,这个位置对应的是master的binlog的位置。

  • Relay_Log_Pos 记录的是SQL thread执行的event在relay
    log中结束位置,这个才是relay log的偏移量。

MySQL的slave端是通过2个线程实现复制的,一个是I/O
Thread负责连接到master接收binlog信息,在从服务器端这部分信息叫做relay log。另一个SQL Thread负责读取relay
log并执行其中的event(在statement format的时候其实就是SQL语句)。当遇到一些I/O Thread或SQL
Thread的报错时,我们可以通过change master
to命令修改连接参数和复制起始点,其中重要的MASTER_LOG_FILE和MASTER_LOG_POS参数,这两个参数对应的是IO线程生成relay
log的信息,因此和Relay_Master_Log_File和Exec_Master_Log_Pos是对应的。

show slave status中的log_file / log_pos,布布扣,bubuko.com

时间: 2024-10-11 20:53:55

show slave status中的log_file / log_pos的相关文章

从show slave status 中判断mysql同步状态

slave status 中检查同步状态: 1.sql线程和io线程显示yes Slave_IO_Running: Yes Slave_SQL_Running: Yes 2. Master_Log_File 和  Relay_Master_Log_File 相等 3. Read_Master_Log_Pos 和 Exec_Master_Log_Pos 相等 4. Slave_SQL_Running_State: 的状态为: Slave_SQL_Running_State: Slave has r

show slave status\G中的Read_Master_Log_Pos和Relay_Log

ust to clarify, there are three sets of file/position coordinates in SHOW SLAVE STATUS: 1) The position, ON THE MASTER, from which the I/O thread is reading:Master_Log_File/Read_Master_Log_Pos. -----相对于主库,从库读取主库的二进制日志的位置,是IO线程 2) The position, IN THE

SHOW SLAVE STATUS 详解

MySQL同步功能由3个线程(master上1个,slave上2个)来实现.执行 DE>START SLAVEDE> 语句后,slave就创建一个I/O线程.I/O线程连接到master上,并请求master发送二进制日志中的语句.master创建一个线程来把日志的内容发送到slave上.这个线程在master上执行 DE>SHOW PROCESSLISTDE> 语句后的结果中的 DE>Binlog DumpDE> 线程便是.slave上的I/O线程读取master的 

两主机搭建MySQL主从复制后,show slave status显示:Last_IO_Error: error connecting to master ……

两台主机A.B搭建mysql主从复制关系(A为master,B为slave)后,在slave上执行show slave status,结果中显示Last_IO_Error: error connecting to master '[email protected]:3306'…… 首先查看B的错误日志文件,发现如下错误: ERROR] Slave I/O: error connecting to master '[email protected]:3306' - retry-time: 60  

mysql系列(一)—— 细说show slave status参数详解(最全)

在搭建好mysql主从之后,我们一般在从库上通过命令 show slave status\G 来查看主从的状态,会有很多的参数,接下来笔者就带大家好好的了解这些参数 [email protected] (none)>show slave status\G *************************** 1. row ***************************                Slave_IO_State: Waiting for master to send e

MySQL show master / slave status 命令参数

一.show master status 二.show slave status Slave_IO_State SHOW PROCESSLIST输出的State字段的拷贝.SHOW PROCESSLIST用于从属I/O线程.如果线程正在试图连接到主服务器,正在等待来自主服务器的时间或正在连接到主服务器等,本语句会通知您 Master_User 被用于连接主服务器的当前用户. Master_Port 当前的主服务器接口. Connect_Retry --master-connect-retry选项

MySQL show slave status命令参数

? Slave_IO_State SHOW PROCESSLIST输出的State字段的拷贝.SHOW PROCESSLIST用于从属I/O线程.如果线程正在试图连接到主服务器,正在等待来自主服务器的时间或正在连接到主服务器等,本语句会通知您 ? Master_User 被用于连接主服务器的当前用户. ? Master_Port 当前的主服务器接口. ? Connect_Retry –master-connect-retry选项的当前值 ? Master_Log_File I/O线程当前正在读取

细说show slave status参数详解(最全)【转】

在搭建好mysql主从之后,我们一般在从库上通过命令 show slave status\G 来查看主从的状态,会有很多的参数,接下来笔者就带大家好好的了解这些参数 [email protected] (none)>show slave status\G *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Hos

master slave status

mysql> show slave status\G; *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 112.124.7.82 Master_User: slaverep Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin