MySQL5.6升級5.7時,出現主從延遲問題排查過程
最近在做zabbix的資料庫MySQL5.6升級5.7時,出現主從延遲問題,這個問題困擾了很久沒有解決,昨天終於解決了,整理了一下整個排查過程,分享給大家。
環境說明:
mysql主庫為5.6的版本,有四個從庫,三個為5.6的版本,一個為5.7的版本,所有主從的庫表結構均一致,5.7的從庫出現大量延遲,5.6的沒問題,業務為zabbix監控,基本全部為insert批次插入操作,每條insert SQL插入資料為400-1000行左右。
問題:
MySQL5.7的從庫大量延遲,relaylog落盤正常,應用到資料庫比較慢,磁碟IO和CPU沒有壓力,sync_binlog為20000或是0沒有區別,max_allowed_packet=128M,innodb_flush_log_at_trx_commit=0,bulk_insert_buffer_size = 128M,binlog_format=row,sync_relay_log=10000,沒有使用並行複製,沒有開啟SSL,沒有開啟GDID,沒有開啟半同步。
排查過程:
1:檢查各個核對各個和效能相關的引數,沒有發現異常。
2:檢查網路卡、硬碟、更換伺服器、資料庫伺服器重啟均沒有效果,5.7的延遲依然存在,排除硬體問題。
3:5.7同步主庫5.6的binlog到relaylog很快,正常,但是relaylog在5.7資料庫中回放效率極低。
4:對比5.6和5.7從庫的show engine innodb status結果:
=============5.6===============================
---BUFFER POOL 1
Buffer pool size 655359
Buffer pool size, bytes 10737401856
Free buffers 1019
Database pages 649599
Old database pages 239773
Modified db pages 119309
Pending reads 0
Pending writes: LRU 0, flush list 0, single page 0
Pages made young 10777670, not young 181119246
13.90 youngs/s, 157.51 non-youngs/s
Pages read 8853516, created 135760152, written 784514803
20.96 reads/s, 58.17 creates/s, 507.02 writes/s
Buffer pool hit rate 1000 / 1000, young-making rate 0 / 1000 not 2 / 1000
Pages read ahead 0.00/s, evicted without access 0.00/s, Random read ahead 0.00/s
LRU len: 649599, unzip_LRU len: 0
I/O sum[209618]:cur[2], unzip sum[0]:cur[0]
=============5.7==============================
---BUFFER POOL 1
Buffer pool size 819100
Buffer pool size, bytes 13420134400
Free buffers 1018
Database pages 722328
Old database pages 266620
Modified db pages 99073
Pending reads 0
Pending writes: LRU 0, flush list 0, single page 0
Pages made young 37153, not young 795
0.00 youngs/s, 0.00 non-youngs/s
Pages read 149632, created 572696, written 2706369
0.00 reads/s, 0.00 creates/s, 0.00 writes/s
Buffer pool hit rate 1000 / 1000, young-making rate 0 / 1000 not 0 / 1000
Pages read ahead 0.00/s, evicted without access 0.00/s, Random read ahead 0.00/s
LRU len: 722328, unzip_LRU len: 453903
I/O sum[98685]:cur[0], unzip sum[882]:cur[6]
+++++++++++++++++++++++
對比發現5.7中unzip存在數值,5.6的沒有,初步懷疑造成延遲的原因和壓縮解壓相關。
5:使用perf top -p
pidof mysqld
檢視5.7從庫
發現libz.so.1.2.7 [.] crc32的佔比要高於mysqld,在6%左右,這個庫和壓縮解壓相關。
6:修改innodb_compression_level的等級為0(就是不啟用壓縮,預設為6,範圍為0-9),觀察無效果,延遲依然存在。只是libz的佔比下去了,但libc-2.17.so的佔比上去了,比mysqld高,在9%左右。使用pstack檢視存在研所解壓的等待的問題。
7:檢查zabbix的歷史表,當時為了節約磁碟空間,對這些表做了壓縮處理:
CREATE TABLE
trends
(
itemid
bigint(20) unsigned NOT NULL,
clock
int(11) NOT NULL DEFAULT '0',
num
int(11) NOT NULL DEFAULT '0',
value_min
double(16,4) NOT NULL DEFAULT '0.0000',
value_avg
double(16,4) NOT NULL DEFAULT '0.0000',
value_max
double(16,4) NOT NULL DEFAULT '0.0000',
PRIMARY KEY (
itemid
,
clock
),
KEY
clock
(
clock
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8
懷疑和ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8這個壓縮引數相關。
8:重建所有歷史表,去掉ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8,,重新同步,延遲逐步降低,恢復。
疑問:為什麼相同的表結構,在5.7中會造成主從延遲而5.6沒有?可能是壓縮和解壓在MySQL5.7中向下相容性問題造成的,沒有深究,但給官方提了一個BUG,讓官方走原始碼層面去看看: 。
在生產中請慎用ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8。和業內幾位專家交流,表示MySQL8.0之前的版本壓縮不太靠譜,8.0的用ZSTD還好一點。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69982209/viewspace-2716291/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL之 從複製延遲問題排查MySql
- centos7 mysql5.6升級5.7CentOSMySql
- Nuxt升級2.0.0時出現的問題UX
- mysql5.6搭建主從過程中遇到主從server_uuid一致無法同步的問題MySqlServerUI
- 如何解決 MySQL 主從延時問題?MySql
- 如何避免MYSQL主從延遲帶來的讀寫問題?MySql
- 【資料庫】mysql5.6升級至5.7(物理方式)資料庫MySql
- MySQL主從資料庫同步延遲問題怎麼解決MySql資料庫
- MySQL 主從切換延時高問題分析MySql
- mysql主從延遲複製MySql
- 主從延遲調優思路
- IDEA使用Tomcat伺服器出現亂碼問題排查過程IdeaTomcat伺服器
- 直播賣貨系統開發,解決HLS實現直播過程中的延遲問題
- 定時器(setTimeout/setInterval)最小延遲的問題定時器
- Jtti:redis主從延遲資料不一致問題如何解決JttiRedis
- mysql的主從複製延遲問題--看這一篇就夠了MySql
- MySQL:雙主單寫 主庫偶爾出現大量延遲的原因MySql
- MySQL主從複製延遲解決方案MySql
- 記一次OOM問題排查過程OOM
- Laravel 5.5.* 升級到 5.7.* 問題記錄Laravel
- 深入剖析:如何使用Pulsar和Arthas高效排查訊息佇列延遲問題佇列
- 💢線上高延遲請求排查
- QWidget設定layout時的延遲重新整理問題
- 主從複製延遲推薦解決方案
- 高頻面試:如何解決MySQL主從複製延時問題面試MySql
- synchronized升級過程synchronized
- Laravel5.5 升級到 5.7 問題及解決方法Laravel
- 分析伺服器延遲的問題伺服器
- 死鎖問題排查過程-間隙鎖的復現以及解決
- MySQL主從複製延遲原因及處理思路MySql
- 主庫千萬級的資料更新後,STANDBY日誌應用大量延遲的問題處理
- 一次IOS通知推送問題排查全過程iOS
- 由於網路延遲造成邏輯鎖過期的問題
- 美國伺服器延遲高怎麼辦,如何解決延遲問題伺服器
- npm install 使用過程出現的問題總結NPM
- docker使用redis過程出現的問題記錄DockerRedis
- SQL Server 2016升級遷移過程中效能問題解決案例SQLServer
- 中科三方:IPv6升級改造過程中有哪些問題?