如果從庫上表 t 數據與主庫不一致,導致復制錯誤,整個庫的數據量很大,重做從庫很慢,如何單獨恢復這張表的數據?通常認為是不能修復單表數據的,因為涉及到各表狀態不一致的問題。下面就列舉備份單表恢復到從庫會面臨的問題以及解岩亂決辦法:
場景 1
如果復制報錯後,沒有使用跳過錯誤、復制過濾等方法修復主從復制。主庫數據一直在更新,從庫數據停滯在報錯狀態(假設 GTID 為 aaaa:1-100)。
修復步驟:
在主庫上備份表 t (假設備份快照 GTID 為 aaaa:1-10000);
恢復到從庫;
啟動復制。
- CHANGE REPLICATION FILTER REPLICATE_WILD_IGNORE_TABLE = ('db_name.t');
- START SLAVE UNTIL SQL_AFTER_GTIDS = 'aaaa:10000';
在主庫上備份表 t (假設備份快照 GTID為 aaaa:1-10000);
停止從庫復制,GTID為 aaaa:1-20000;
恢復表 t 到從庫;
啟動復制。
對表 t 加讀鎖;
在主庫上備份表 t;
停止從庫復制,恢復表 t;
啟動復制;
解鎖表 t。
這里的問題是復制起始位點是 aaaa:101,從庫上表 t 的數據狀態是領先其他表的。aaaa:101-10000 這些事務中只要有修改表 t 數據的事務,就會導致復制報錯 ,比如主鍵沖突、記錄不存在(而 aaaa:101 這個之前復制報錯的事務必定是修改表 t 的事務)
解決辦法:啟動復制時跳過 aaaa:101-10000 這些事務中修改表 t 的事務。
正確的修復步驟:
1. 在主庫上備份表 t (假設備份快照 GTID 為 aaaa:1-10000),恢復到從庫;
2. 設置復制過濾,過濾表 t:
3. 啟動復制,回放到 aaaa:10000 時停止復制(此時從庫上所有表的數據都在同一狀態,是一致的);
4. 刪除復制過濾,正常啟動復制。
注意事項:這里要用 mysqlmp --single-transaction --master-data=2,記錄備份快巧譽照對應的 GTID
場景 2
如果復制報錯後,使用跳過錯孝棗段誤、復制過濾等辦法修復了主從復制。主、從庫數據一直在更新。
修復步驟:
這里的問題是復制起始位點是 aaaa:20001,aaaa:10000-20000 這些事務將不會在從庫上回放,如果這裡面有修改表 t 數據的事務,從庫上將丟失這部分數據。
解決辦法:從備份開始到啟動復制,鎖定表 t,保證 aaaa:10000-20000 中沒有修改表 t 的事務。
正確修復步驟:
如果是大表,這里可以用可傳輸表空間方式備份、恢復表,減少鎖表時間。
⑵ mysql導入文件報錯,數據會進去嗎
mysql導入sql文件報錯的原因
1.在討論這個問題之前,先介紹一下什麼是「大數據量sql文件」。
導出sql文件。
導入mysql sql文件出錯的原因,導入資料庫出錯的原因。
選擇資料庫-右鍵單擊並選擇轉儲SQL文件-選擇結構和數據。保存文件db_mras.sql文件。
2.導入sql文件。在MYSQL中新建一個資料庫db_mras。
導入mysql sql文件出錯的原因,導入資料庫出錯的原因。
選擇database——右擊並選擇「運行SQL文件」——選擇文件db_mras.sql並運行它。
現在發現操作失敗,提示錯誤「MySQL伺服器已經不在了」喚陵廳。為了解決這個問題,提出了以下解決方案:
這個錯誤意味著汪友客戶端和mysql之間的鏈接斷開了,通常是因為sql運行時間太長或者sql文件太大。
排除問題原因:
(1)mysql服務宕機。
運行命令:顯示全局狀態,如「正常運行時間」;如果uptime的值很大,說明最近沒有重啟mysql服務。如果日誌中沒有相關信息,說明服務沒有重啟,可以排除這種可能。
(2)mysql鏈接超時
運行命令:顯示像「% timeout」這樣的全局變數;檢查運行結果中wait_timeout的值,一般為28800。意味著mysql鏈和隱接在誤操作28800秒後會被關閉。
(3)mysql文件過大
運行命令:顯示像「max _ allowed _ packet」這樣的全局變數;檢查max_allowed_packet的值作為運行結果。如果太小,就需要調整。
解決方法:
在mysql的my.ini文件末尾添加以下文字:wait _ timeout = 2880000interactive _ time = 2880000max _ allowed _ packet = 16M
其中max_allowed_packet表示控制緩沖區的最大長度。wait_timeout表示無操作環節的等待時間。
修改以上參數後重啟mysql服務。
檢查修改是否成功:運行命令:顯示' % timeout '之類的全局變數;顯示全局變數,如「max _ allowed _ packet」;
如果找不到my.ini文件,可以運行命令:MySQL–help | grep my . ini查找文件路徑。
如果以上方法不能解決你的問題,你還需要檢查一下你的mysql文件安裝盤是否有足夠的空間。
⑶ 在ds窗口中導入MYSQL資料庫時報error 1049 (42000):Unknown database ';'這個錯誤
在ds窗口中導入MYSQL資料庫時報error 1049 (42000):Unknown database '是設置錯誤造成的,解決方法為:
1、打開cmd,輸入mysql -u 用戶名 -p回車根據提示輸入密碼,如下圖。