您好,登錄后才能下訂單哦!
這篇文章主要介紹“mysql主從復制中出現的error和解決方法”,在日常操作中,相信很多人在mysql主從復制中出現的error和解決方法問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”mysql主從復制中出現的error和解決方法”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
主從復制中出現的error和解決方法
slave日志中的錯誤代碼1:
[ERROR] Error reading packet from server: Client requested master to start replication from impossible position; the last event was read from 'mysql-bin.000016' at 455562731, the last byte read was read from 'mysql-bin.000016' at 4. ( server_errno=1236)
120725 23:19:17 [ERROR] Slave I/O: Got fatal error 1236 from master when reading data from binary log: 'Client requested master to start replication from impossible position; the last event was read from 'mysql-bin.000016' at 455562', Error_code: 1236
解救辦法: www.2cto.com
先查看主服務器中對應日志文件是否有此行,使用的命令是
mysqlbinlog /YOURPATH/'mysql-bin.000016 >>/test
查找有沒有455562對應的行 或者和這個數字很接近的行 然后使用chang master to 命令跳過這行,命令格式如下
stop slave;
CHANGE MASTER TO MASTER_HOST='192.168.192.45',MASTER_USER='XXXX',MASTER_PASSWORD='XXXX',MASTER_LOG_FILE='mysql-bin.000016',MASTER_LOG_POS=455678;
start slave;
如果你找不到455562或者和這個數字很接近的行,你可以使用如下命令查看'mysql-bin.000016 的行數
ls -la mysql-bin.000016
如果統計的行數遠遠少于455562,你可以跳過這個日志,從下一個日志開始復制,命令如下
stop slave;
CHANGE MASTER TO MASTER_HOST='192.168.192.45',MASTER_USER='backup',MASTER_PASSWORD='weiphone',MASTER_LOG_FILE='mysql-bin.000017',MASTER_LOG_POS=4;
start slave; www.2cto.com
錯誤類型代碼2:
mysql slave Error_code: 1062 1054
如果日志中出現了這樣代碼,可能是錯誤的select,或update操作,master是跳過這些操作,但是被記錄到了二進制日志中,slave會依據二進制中的語句做相同的動作,就會報錯,知道原理了要做的操作就很簡單了
stop slave;
set gloable sql_slave_skip_counter=n; //n為你想跳過錯誤語句的個數
start slave;
如果你不想再遇到這種錯誤,可以寫到slave配置文件中格式如下:
slave_skip_errors = 1062
slave_skip_errors = all //跳過所有類型的錯誤碼
到此,關于“mysql主從復制中出現的error和解決方法”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。