广告
返回顶部
首页 > 资讯 > 数据库 >怎么解决Mysql中Slave延迟很大并且不动了问题
  • 681
分享到

怎么解决Mysql中Slave延迟很大并且不动了问题

2024-04-02 19:04:59 681人浏览 薄情痞子
摘要

这篇文章主要介绍“怎么解决Mysql中Slave延迟很大并且不动了问题”,在日常操作中,相信很多人在怎么解决mysql中Slave延迟很大并且不动了问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操

这篇文章主要介绍“怎么解决Mysql中Slave延迟很大并且不动了问题”,在日常操作中,相信很多人在怎么解决mysql中Slave延迟很大并且不动了问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么解决Mysql中Slave延迟很大并且不动了问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

问题描述

收到SLAVE延迟时间一直很大的报警,于是检查一下SLAVE状态(无关状态我给隐去了):

  1.  Slave_io_State: Waiting for master to send event       Master_Log_File: mysql-bin.000605                ---当前master的binlog    

  2. Read_Master_Log_Pos: 305864                          ---master binlog位置         

  3.  Relay_Log_File: mysql-relay-bin.003224           Relay_Log_Pos: 295105   Relay_Master_Log_File: mysql-bin.000604                ----当前salve同步到的master的binlog日志 

  4.        Slave_IO_Running: Yes       Slave_SQL_Running: Yes              Last_Errno: 0              Last_Error:     Exec_Master_Log_Pos: 294959                          -----当前slave执行到的master的binlog 的pos 

  5.         Relay_Log_Space: 4139172581   Seconds_Behind_Master: 10905                           ---延迟 一般是Read_Master_Log_Pos-Exec_Master_Log_Pos


可以看到,延迟确实很大,而且从多次show slave status的结果来看,发现binlog的position一直不动。

点击(此处)折叠或打开

  1. Relay_Master_Log_File: mysql-bin.000604

  2.   Exec_Master_Log_Pos: 294959

  3.       Relay_Log_Space: 4139172581

检查processlist 也没发现异常sql语句

在master上查看相应binlog,确认都在干神马事:

  1. [yejr@imysql.com]# mysqlbinlog -vvv --base64-output=decode-rows -j 294959 mysql-bin.000604 | more

  2. --base64-output=decode-rows --去除一些不必要的二进制日志展示 ; ; DELIMITER ; **# at 294959** #160204  6:16:30 server id 1  end_log_pos 295029     **Query    thread_id=461151**    **exec_time=2144**    error_code=0 SET TIMESTAMP=1454537790; SET @@session.pseudo_thread_id=461151; SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1; SET @@session.sql_mode=0; SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1; ; SET @@session.character_set_client=8,@@session.collation_connection=8,@@session.collation_server=33; SET @@session.lc_time_names=0; SET @@session.collation_database=DEFAULT; BEGIN ; # at 295029 # at 295085 # at 296040 # at 297047 # at 298056 # at 299068 # at 300104

  3. 上面这段内容的几个关键信息:

  4. # at 294959   — binlog起点
    thread_id=461151    — master上执行的线程ID
    exec_time=2144    — 该事务执行总耗时


再往下看都是一堆的binlog position信息,通过这种方式可读性不强,我们换一种姿势看看

  1. [yejr@imysql.com (test)]> show binlog events in 'mysql-bin.000604' from 294959 limit 10; +------------------+--------+-------------+-----------+-------------+----------------------------+ | Log_name         | Pos    | Event_type  | Server_id | End_log_pos | Info                       | +------------------+--------+-------------+-----------+-------------+----------------------------+ | mysql-bin.000604 | 294959 | Query       |         1 |      295029 | BEGIN                      | | mysql-bin.000604 | 295029 | Table_map   |         1 |      295085 | table_id: 84 (bacula.File) | | mysql-bin.000604 | 295085 | Delete_rows |         1 |      296040 | table_id: 84               | | mysql-bin.000604 | 296040 | Delete_rows |         1 |      297047 | table_id: 84               | | mysql-bin.000604 | 297047 | Delete_rows |         1 |      298056 | table_id: 84               | | mysql-bin.000604 | 298056 | Delete_rows |         1 |      299068 | table_id: 84               | | mysql-bin.000604 | 299068 | Delete_rows |         1 |      300104 | table_id: 84               | | mysql-bin.000604 | 300104 | Delete_rows |         1 |      301116 | table_id: 84               | | mysql-bin.000604 | 301116 | Delete_rows |         1 |      302147 | table_id: 84               | | mysql-bin.000604 | 302147 | Delete_rows |         1 |      303138 | table_id: 84               |

可以看到,这个事务不干别的,一直在删除数据。
这是一个Bacula备份系统,会每天自动删除一个月前的过期数据。
事实上,这个事务确实非常大,从binlog的294959开始,一直到这个binlog结束4139169218,一直都是在干这事,总共大概有3.85G的binlog要等着apply。

  1. -rw-rw---- 1 mysql mysql 1.1G Feb  3 03:07 mysql-bin.000597

  2. -rw-rw---- 1 mysql mysql 1.1G Feb  3 03:19 mysql-bin.000598

  3. -rw-rw---- 1 mysql mysql 2.1G Feb  3 03:33 mysql-bin.000599

  4. -rw-rw---- 1 mysql mysql 1.4G Feb  3 03:45 mysql-bin.000600

  5. -rw-rw---- 1 mysql mysql 1.8G Feb  3 04:15 mysql-bin.000601

  6. -rw-rw---- 1 mysql mysql 1.3G Feb  3 04:53 mysql-bin.000602

  7. -rw-rw---- 1 mysql mysql 4.5G Feb  4 06:16 mysql-bin.000603

  8. -rw-rw---- 1 mysql mysql 3.9G Feb  4 06:52 mysql-bin.000604

  9. -rw-rw---- 1 mysql mysql 1.2K Feb  4 06:52 mysql-bin.000605

怎么解决

由于这是Bacula备份系统内置生成的大事务,除非去修改它的源码,否则没有太好的办法。

对于我们一般的应用而言,最好是攒够一定操作后,就先提交一下事务,比如删除几千条记录后提交一次,而不是像本例这样,一个删除事务消耗了将近3.9G的binlog日质量,这种就非常可怕了。

除了会导致SLAVE看起来一直不动以外,还可能会导致某些数据行(data rows)被长时间定不释放,而导致大量行锁等待发生。

到此,关于“怎么解决Mysql中Slave延迟很大并且不动了问题”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么解决Mysql中Slave延迟很大并且不动了问题

本文链接: https://www.lsjlt.com/news/66916.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么解决Mysql中Slave延迟很大并且不动了问题
    这篇文章主要介绍“怎么解决Mysql中Slave延迟很大并且不动了问题”,在日常操作中,相信很多人在怎么解决Mysql中Slave延迟很大并且不动了问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2022-10-19
  • 怎么解决wamp5的mysql服务启动不了问题
    怎么解决wamp5的mysql服务启动不了问题,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 最近由于公司需求,开始学习。。...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作