show slave statusG中的Read_Master_Log_Pos和Relay_Log的用法是怎样的


本篇文章为大家展示了show slave statusG中的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 RELAY LOGS, at which the SQL thread is executing:Relay_Log_File/Relay_Log_Pos —-相对于从库,是从库的sql线程执行到的位置3) The position, ON THE MASTER, at which the SQL thread is executing:Relay_Master_Log_File/Exec_Master_Log_Pos —-相对于主库,是从库的sql线程执行到的位置Numbers 2) and 3) are the same thing, but one is on the slave and the other is on the master.mysql > show slave status GMaster_Log_File: mysql-bin-m.000329Read_Master_Log_Pos: 863952156 —-上面二行代表IO线程,相对于主库的二进制文件Relay_Log_File: mysql-relay.003990Relay_Log_Pos: 25077069 —-上面二行代表了sql线程,相对于从库的中继日志文件Relay_Master_Log_File: mysql-bin-m.000329…..Exec_Master_Log_Pos: 863936961—上面二行代表了sql线程,相对主库(为了方便演示,我把上面这行提前了.)Relay_Log_Space: 25092264—当前relay-log文件的大小Slave_IO_Running: YesSlave_SQL_Running: Yes从上面可以看到,read_master_log_pos 始终会大于exec_master_log_pos的值(也有可能相等):因为一个值是代表io线程,一个值代表sql线程;sql线程肯定在io线程之后.(当然,io线程和sql线程要读写同一个文件,否则比较就失去意义了) .在binlog中,Xid代表了提交的事务号.现在我们分别去主从库看看,验证一下,在主库的mysql-bin-m.000329文件的863936961处是否与从库的mysql-relay.003990文件的25077069处有相同的sql语句.先看主库的binlog:#at 863936961#100111 20:11:39 server id 115000 end_log_pos 863937234 Query thread_id=515886 exec_time=0 error_code=0use mall00/!/;UPDATE mall00.t_item_sid88 SET item_end_time = 1263816699, item_is_online = 1, item_status = 1 WHERE iid IN (94322390, 94322428, 94322452, 94322473, 94322506, 94322532, 94322604, 94322641, 94322670, 94322706)/!/;#at 863937234#100111 20:11:39 server id 115000 end_log_pos 863937261 Xid = 1225244590COMMIT/!/;#at 863937261#100111 20:11:39 server id 115000 end_log_pos 863937457 Query thread_id=515886 exec_time=0error_code=0SET TIMESTAMP=1263211899/!/;再看从库的relaylog:#at 25077069#100111 20:11:39 server id 115000 end_log_pos863937234 Query thread_id=515886 exec_time=0 error_code=0use mall00/!/;UPDATE mall00.t_item_sid88 SET item_end_time = 1263816699, item_is_online = 1, item_status = 1 WHERE iid IN (94322390, 94322428, 94322452, 94322473, 94322506, 94322532, 94322604, 94322641, 94322670, 94322706)/!/;#at 25077342#100111 20:11:39 server id 115000 end_log_pos 863937261 Xid = 1225244590COMMIT/!/;从上面的日志中,可以看到binlog与realy-log的内容是相同的,除了开头的at位置处的偏移量.因为偏移量始终是相对于文件自身来说,主库上相对于binlog本身,从库上相对于relay-log本身.还可以看到,在每个query语句过后,都有一个Xid 的event,提交该事务,也表明在mysql中是自动提交的,每条语句执行完毕开发云主机域名后,系统都自动提交了.那么在基于行的复制中,可能会看到多条binlog 语句才对应一次commit,自然说明这是基于行的复制.还有一点,就是主库和从库的对应位置的event大小是相同的,例如上面的:25077342-25077069(从库上event大小) = 863937234-863936961(主库上event大小)否则,说明从库的relay-log丢失了,有可能是操作系统缓存丢失,也可能是mysql 异常crash导致relay-log buffer中的数据丢失.那么这时候就需要重设主从同步了.上述内容就是show slave statusG中的Read_Master_Log_Pos和Relay_Log的用法是怎样的,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注开发云行业资讯频道。

相关推荐: MySQL中的if和case语句怎么用

小编给大家分享一下MySQL中的if和case语句怎么用,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!Mysql的if既可以作为表达式用,也可在存储过程中作为流程控制语句使用,如下是做为表达式使用:IF表达式如果 expr1 是TRUE (exp…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 06/21 20:02
Next 06/21 20:02

相关推荐