使用mysqldump備份時(shí)為什么要加上 -q 參數(shù)

2018-02-24 16:05 更新

mysqldump

寫在前面:我們?cè)谑褂胢ysqldump備份數(shù)據(jù)時(shí),請(qǐng)一定記住要加上?-q?參數(shù),后果可能是很嚴(yán)重的,不要給自己挖坑哦。到底為什么呢,且聽我慢慢道來(lái)!

先來(lái)看看 mysqldump –help 中,關(guān)于 -q 參數(shù)的解釋:

-q, --quick???????? Don't buffer query, dump directly to stdout.

簡(jiǎn)言之,就是說(shuō)加上 -q 后,不會(huì)把SELECT出來(lái)的結(jié)果放在buffer中,而是直接dump到標(biāo)準(zhǔn)輸出中,頂多只是buffer當(dāng)前行結(jié)果,正常情況下是不會(huì)超過(guò) max_allowed_packet 限制的,它默認(rèn)情況下是開啟的。

如果關(guān)閉該參數(shù),則會(huì)把SELECT出來(lái)的結(jié)果放在本地buffer中,然后再輸出給客戶端,會(huì)消耗更多內(nèi)存。

在mysqldump.c中也能看到二者的對(duì)比(現(xiàn)在流行深入源碼,雖然我不是專注開發(fā)的,找?guī)仔性创a能力還尚存,用來(lái)裝B的,大家知道就好,哈哈):

if (quick)
  res=mysql_use_result(sock);
else
  res=mysql_store_result(sock);

有理論,也要有實(shí)踐不是,我們來(lái)看看在實(shí)際場(chǎng)景中,加不加 -q 的區(qū)別有多大。

備份方式 部分備份(啟用-q) 部分備份(禁用-q) 完整備份(啟用-q) 完整備份(禁用-q)
備份總耗時(shí) 27.882秒 22.665秒 277.387秒 217.074秒
占用內(nèi)存(含swap) 3056KB 2.5GB 3048KB 內(nèi)存:12GBswap:305MB

可以看到,如果只是備份小量數(shù)據(jù),足以放在空閑內(nèi)存buffer中的話,禁用 -q 會(huì)快一些,但如果是大數(shù)據(jù)集,沒(méi)辦法完全hold在內(nèi)存buffer中時(shí),就會(huì)產(chǎn)生swap,效率反而更差,真是賠了夫人又折兵。

因此,如果使用mysqldump來(lái)備份數(shù)據(jù)時(shí),建議總是加上 -q 參數(shù),避免發(fā)生swap反而影響備份效率。

詳細(xì)過(guò)程(有耐心的可以繼續(xù)往下看)

1、全量備份:備份時(shí)不使用 -q 參數(shù)

mysqldump --quick=false -Smysql.sock -B yejr --tables t_yejr

#先看下一開始時(shí)的狀態(tài):
Mem:? 32863040k total, 29338704k used,? 3524336k free,?? 227632k buffers
Swap: 16777208k total,??? 23548k used, 16753660k free,? 8200416k cached
PID USER????? PR? NI? VIRT? RES? SHR S %CPU %MEM??? TIME+? COMMAND
21986 root????? 20?? 0 6119m 5.9g 2192 S 20.6 18.9?? 0:21.69 mysqldump

#再看下備份結(jié)束后的狀態(tài),內(nèi)存不夠用,產(chǎn)生了swap
Mem:? 32863040k total, 32521328k used,?? 341712k free,????? 440k buffers
Swap: 16777208k total,?? 336876k used, 16440332k free,?? 315192k cached
PID   USER????? PR? NI? VIRT? RES? SHR S %CPU %MEM??? TIME+?  COMMAND
21986 root????? 20?? 0 12.3g? 12g? 656 R 100.0 39.1?? 2:23.93 mysqldump

#最后看下備份總耗時(shí)
real??? 4m37.387s
user??? 2m2.731s
sys???? 0m24.608s

2、全量備份:備份時(shí)啟用 -q 參數(shù)

mysqldump -Smysql.sock -B yejr --tables t_yejr

#先看下一開始時(shí)的狀態(tài):
Mem:? 32863040k total, 20157476k used, 12705564k free,???? 4608k buffers
Swap: 16777208k total,??????? 0k used, 16777208k free,?? 488296k cached

#再看下備份結(jié)束后,可以看到,沒(méi)有使用到swap
Mem:? 32863040k total, 32644496k used,?? 218544k free,????? 920k buffers
Swap: 16777208k total,??????? 0k used, 16777208k free, 12618740k cached
PID   USER????? PR? NI? VIRT? RES? SHR S %CPU %MEM??? TIME+? COMMAND
25234 root????? 20?? 0 50880 3048 2192 S 57.6? 0.0?? 2:22.79 mysqldump

#最后看下總耗時(shí)統(tǒng)計(jì):
real??? 3m37.074s
user??? 2m6.018s
sys???? 0m17.315s

3、部分備份:備份時(shí)不使用 -q 參數(shù)

mysqldump -w " id<100000 " -Smysql.sock --quick=false -Smysql.sock -B yejr --tables t_yejr

#看下總耗時(shí)
real 0m22.665s
user 0m20.458s
sys 0m2.156s

#再看下mysqldump進(jìn)程消耗的內(nèi)存,最高時(shí)大概使用了2.5G內(nèi)存
20619 root ? ? ?20 ? 0 2571m 2.5g 2208 R 99.9 ?7.8 ? 0:11.63 mysqldump

4、部分備份:備份時(shí)啟用 -q 參數(shù)

mysqldump -w " id<100000 " -Smysql.sock -Smysql.sock -B yejr --tables t_yejr

#看下總耗時(shí),并沒(méi)有慢多少
real 0m27.882s
user 0m22.610s
sys 0m0.670s

#再看下mysqldump進(jìn)程消耗的內(nèi)存,只占用了極少量?jī)?nèi)存
19690 root ? ? ?20 ? 0 50880 3056 2200 S 73.4 ?0.0 ? 0:06.01 mysqldump
以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)