真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

【MySQL】如何快速執(zhí)行binlog

【背景】
維護(hù)MySQL的時候,總會遇到數(shù)據(jù)庫恢復(fù)的例子。如果把備份集恢復(fù)出來相對比較簡單。然而如果遇到恢復(fù)到時間點(diǎn)的例子,把一個MySQL實(shí)例恢復(fù)出來之后,需要執(zhí)行binlog做增量恢復(fù)。

【方法一】
常見的辦法是用mysqlbinlog解析binlog,將解析出來的內(nèi)容重定向到mysql命令行執(zhí)行。
#start是mysql-bin后面的數(shù)字

點(diǎn)擊(此處)折疊或打開

成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比南皮網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式南皮網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋南皮地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴。

  1. i=start
  2. while [ $i -lt end ]
  3. do
  4. mysqlbinlog mysql-bin.$i | mysql -h 127.0.0.1 -P 4001 -uroot > 0550.log 2>&1
  5. done
這樣做確實(shí)可以,而且row模式的binlog,也可以通過這種方式來執(zhí)行。但是這樣做有幾個缺點(diǎn)
1. 如果解析出來的binlog在執(zhí)行的過程中報錯,如何處理?直接加 -f 強(qiáng)制執(zhí)行嗎?
2. 執(zhí)行中途如何停下來,下次接著跑? 比如我想調(diào)整一下MySQL的參數(shù)(需要重啟)后繼續(xù)跑?
3. 只能單線程執(zhí)行。而且mysqlbinlog解析再通過管道執(zhí)行,有比較高的性能開銷。

鑒于上面的缺點(diǎn) 下面隆重推出執(zhí)行大量binlog的另外一種方法
【方法二】
我們都知道relay-log的內(nèi)容和binlog的內(nèi)容其實(shí)都是一樣的,那么我是否能把binlog作為relay-log來執(zhí)行呢?
答案是肯定的,屢試不爽。
詳細(xì)的步驟:
0. 先把實(shí)例正常shutdown
1. 把binlog上傳到mysql服務(wù)器本地磁盤,放到一個固定的目錄,如/home/mysql/restore_1031
2. 如果是M-S 架構(gòu),則需要修改master.info,寫入如下內(nèi)容


點(diǎn)擊(此處)折疊或打開

  1. cat > $BINLOG_DIR/master.info<
  2. 18
  3. dummy.binlog
  4. 0
  5. dummy.host
  6. repl
  7. repl
  8. 3306
  9. 60
  10. 0










  11. 0
  12. 0.000


  13. 0


  14. EOF
這里的內(nèi)容需要符合規(guī)則,只要不指向slave 就好,避免應(yīng)用slave的sql。
3. 修改slave-relay-log.info, 把$STAET, $START_BINLOG_POS替換成你需要開始執(zhí)行的binlog的文件名和start-position

點(diǎn)擊(此處)折疊或打開

  1. cat > $BINLOG_DIR/relay-log.info <
  2. /home/mysql/restore_1031/mysql-bin.$STAET
  3. $START_BINLOG_POS
  4. dummy-binlog.1
  5. 0
  6. EOF
4. 修改slave-relay-log.index, 把你需要執(zhí)行的binlog列表都放進(jìn)去。

點(diǎn)擊(此處)折疊或打開

  1. #head slave-relay-log.index
  2. /home/mysql/restore_1031/mysql-bin.000588
  3. /home/mysql/restore_1031/mysql-bin.000589
  4. /home/mysql/restore_1031/mysql-bin.000590
  5. /home/mysql/restore_1031/mysql-bin.000591
  6. /home/mysql/restore_1031/mysql-bin.000592
5. 啟動mysql實(shí)例,執(zhí)行start slave sql_thread。

使用方法二的好處:
解決了上面用mysqlbinlog解析再管道給mysql執(zhí)行的各個缺陷。
1 可以隨時stop slave,調(diào)整一些參數(shù),再start slave。
2 可以選擇忽略一些slave執(zhí)行報錯。
3 如果你的mysql版本支持多線程復(fù)制,你還可以使用它 start slave multi_sql_thread 而且這么做性能更好,在一個數(shù)據(jù)恢復(fù)的場景中,

性能對比:
使用mysqlbinlog 加管道的方式,每秒只能執(zhí)行3000不到IUD,
使用mysql原生slave執(zhí)行的方式,每秒可以執(zhí)行8000 IUD。
缺點(diǎn):修改master.info slave-relay-log.info等文件,需要重啟實(shí)例才會生效。

下一次,如果你需要恢復(fù)大量binlog,你會選擇哪種方式?

本文標(biāo)題:【MySQL】如何快速執(zhí)行binlog
文章網(wǎng)址:http://weahome.cn/article/ihjhjg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部