91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

【MySQL】如何快速執行 binlog

發布時間:2020-08-08 00:36:38 來源:ITPUB博客 閱讀:160 作者:kunlunzhiying 欄目:建站服務器
【背景】
維護mysql的時候,總會遇到數據庫恢復的例子。如果把備份集恢復出來相對比較簡單。然而如果遇到恢復到時間點的例子,把一個MySQL實例恢復出來之后,需要執行binlog做增量恢復。

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

點擊(此處)折疊或打開

  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
這樣做確實可以,而且row模式的binlog,也可以通過這種方式來執行。但是這樣做有幾個缺點
1. 如果解析出來的binlog在執行的過程中報錯,如何處理?直接加 -f 強制執行嗎?
2. 執行中途如何停下來,下次接著跑? 比如我想調整一下MySQL的參數(需要重啟)后繼續跑?
3. 只能單線程執行。而且mysqlbinlog解析再通過管道執行,有比較高的性能開銷。

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


點擊(此處)折疊或打開

  1. cat > $BINLOG_DIR/master.info<<eof
    </eof
  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
這里的內容需要符合規則,只要不指向slave 就好,避免應用slave的sql。
3. 修改slave-relay-log.info, 把$STAET, $START_BINLOG_POS替換成你需要開始執行的binlog的文件名和start-position

點擊(此處)折疊或打開

  1. cat > $BINLOG_DIR/relay-log.info <<EOF
  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, 把你需要執行的binlog列表都放進去。

點擊(此處)折疊或打開

  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實例,執行start slave sql_thread。

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

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

下一次,如果你需要恢復大量binlog,你會選擇哪種方式?
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乳山市| 石林| 墨竹工卡县| 喀喇沁旗| 沂源县| 富川| 白银市| 外汇| 木里| 濮阳县| 凤凰县| 万荣县| 呼图壁县| 乡城县| 天津市| 登封市| 白山市| 安塞县| 东丰县| 高州市| 闻喜县| 远安县| 贡嘎县| 琼中| 武强县| 双峰县| 自贡市| 策勒县| 南投市| 清苑县| 威宁| 太白县| 河池市| 梁山县| 郎溪县| 图片| 贵阳市| 孝感市| 浮山县| 西和县| 兴城市|