Mysql主从延迟解决办法

1.MIXED模式无索引或SQL慢

在从库上pager grep -v Sleep;show processlist 查看到正在执行的SQL。

解决方法:

a. SQL比较简单, 则检查是否缺少索引,并添加索引。比如update操作where条件没有索引。

b. 另一类是 insert into select from的语句,如果select 里包含group by,多表关联,可能效率会比较低。这类可以到主库把binlog_format改成row。

2. 主库上有大事务,导致从库延时 现象解析binlog 发现类似于下图的情况看

解决方法:

与开发沟通,增加缓存,异步写入数据库,减少直接对db的大量写入。

3. 主库写入频繁,从库压力跟不上导致延时

此类原因的主要现象是数据库的IUD(插改删) 操作非常多,slave由于sql_thread单线程的原因追不上主库。 解决方法:

a. 升级从库的硬件配置,比如ssd、fio

b. 设置日志刷新频率:

set global innodb_flush_log_at_trx_commit=0;

setglobal sync_binlog=0;

  • innodb_flush_log_at_trx_commit=0每秒将log_buffer刷新到logfile,并且将日志同步刷新到磁盘。该模式下,在事务提交的时候,不会主动触发写入磁盘的操作。
  • innodb_flush_log_at_trx_commit=1每次commit将log_buffer刷新到logfile,并且将日志同步刷新到磁盘
  • innodb_flush_log_at_trx_commit=2 每次commit将log_buffer刷新到logfile,但是flush(刷到磁盘)操作并不会同时进行,每秒将日志刷新到磁盘。

4. 数据库中存在大量myisam表,在备份的时候导致slave延迟

由于xtrabackup工具备份到最后会执行flash tables with read lock,对数据库进行锁表以便进行一致性备份,然后对于myisam表锁,会阻碍salve_sql_thread停滞运行进而导致hang。

该问题目前的比较好的解决方式是修改表结构为innodb存储引擎的表。

原文发布于微信公众号 - MYSQL轻松学(learnmysql)

原文发表时间:2016-09-21

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏晨星先生的自留地

DNS(上) 之原理与搭建篇

1363
来自专栏我和PYTHON有个约会

数据库连接引擎那点事儿

天长,地久。天地之所以能长且久者,以其不自生也,故能长生。是以圣人后其身而身先,外其身而身存,非以其无私邪?故能成其私。——老子

662
来自专栏前端正义联盟

gitflow 开发流程学习(第二部分)

1276
来自专栏IT大咖说

深入浅出XTTS:Oracle数据库迁移升级利器

摘要 通常我们要进行数据迁移,可以使用的方案有很多,比如数据泵、RMAN、GoldenGate,甚至是第三方同步软件DSG、DDS等。但是对于传统的迁移方式来说...

3827
来自专栏智能算法

必须掌握的Navicat for SQLite 所有功能

Navicat for SQLite是一套强大和全面的SQLite图形用户介面工具,提供完整的服务器管理功能。它配备了数据编辑、SQL查询和数据模型工具,并支持...

4675
来自专栏小俊博客

【开源】小Z为DNSmasq写了一个WEB界面PHPDNS

DNSmasq是一个小巧且方便地用于配置DNS和DHCP的工具,适用于小型网络,它提供了DNS功能和可选择的DHCP功能。使用DNSmasq可以很方便的搭建递归...

992
来自专栏idba

MySQL常见slave延迟原因以及解决方法

一 序言 在运维线上M-M 架构的MySQL数据库时,接收的比较多关于主备延时的报警:

843
来自专栏张戈的专栏

php平滑重启nginx,彻底清除WordPress的静态缓存

每一次分享技术文章,都是基于自己的痛点,基于自己的需求。这次也一样,所以分享具体方法之前,我先说一下我这次的需求与痛点: 一、需求痛点 在博客集成了代码版缓存功...

2889
来自专栏Python数据科学

Scrapy+MongoDB 轻松爬取海量妹子图

【原文链接】:https://mp.weixin.qq.com/s/WIrepTu-2CGrGifLLRsHjw

801
来自专栏LeoXu的博客

使用 Chrome 浏览器调试 WebView 中的网页

然后呢,运行 Android 程序,再打开 Chrome 浏览器,在地址栏输入 chrome://inspect/#devices,回车,然后找到这个 devi...

753

扫码关注云+社区