您好,登錄后才能下訂單哦!
假設
innodb cluster集群跑了1年,突然某個節點掛掉了,這個時候,日志也已經沒有binlog.000001了,如果在線增加一個從庫呢,官方給出基于mysqlbackup
的恢復方式,在剩余從庫上做備份,在新從庫上恢復,這里有些技術點,我忽略了,苦惱很久。
頻繁操作數據寫入庫,切換四個binlog。flush logs , show binary logs
從庫2的binlog 和relay-log
可以看到,主庫切換日志,從庫并不進行切換
清理掉第1,2個binglog,再寫入一些數據,PURGE MASTER LOGS TO 'binlog.000003';
mysqlbackup --host=127.0.0.1 --port=3310 --user=backup --password=$$$$$$$$ --no-history-logging --backup-dir=/data/backup/fullbak --with-timestamp backup-and-apply-log
--no-history-logging 因為 在從庫操作,不能寫備份信息到數據庫中
備份壓縮拷貝到從機,并解壓
scp root@192.168.181.105:/data/backup/fullbak/2018-07-25_14-32-32.tar.gz .
tar -xzvf 2018-07-25_14-32-32.tar.gz
拷貝活著的從庫的配置文件,修改組復制部分的信息
恢復從庫數據庫
mysqlbackup --defaults-file=/data/mysql_3310_test/conf/my.cnf --backup-dir=/data/backup/fullbak/2018-07-26_20-59-35 copy-back-and-apply-log
關閉日志記錄:
set sql_log_bin=off;
use mysql
delete from slave_relay_log_info ;
delete from slave_master_info ;
set sql_log_bin=on;
注意這里不能執行
Reset master 和reset slave
和
Drop database mysql_innodb_cluster_metadata
重啟一次數據庫,應該沒有報錯了
強制刪除掛掉的實例cluster.removeInstance('root@mysql4:3310',{force:1})
增加實例cluster.addInstance('root@mysql4:3310')
組復制的增加成員方式和innodb cluster集群增加成員方式不同,
. 組復制 有reset master 和reset slave 操作,還包括了設置gtid的操作
set @@GLOBAL.GTID_PURGED='80d2433f-8f24-11e8-a8df-000c29f1584d:123';
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。