这篇文章给大家分享的是有关mysql主从同步怎么跳过错误的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

mysql主从同步跳过错误的方法:1、跳过指定数量的事务,代码为【mysql>SET GLOBAL SQL_SLAVE_SKIP..】;2、修改mysql的配置文件,通过【slave_skip_errors】参数来跳所有错误。

mysql主从同步跳过错误的方法:

1、跳过指定数量的事务:

mysql>slavestop;mysql>SETGLOBALSQL_SLAVE_SKIP_COUNTER=1#跳过一个事务mysql>slavestart

2、修改mysql的配置文件,通过slave_skip_errors参数来跳所有错误或指定类型的错误

vi/etc/my.cnf[mysqld]#slave-skip-errors=1062,1053,1146#跳过指定errorno类型的错误#slave-skip-errors=all#跳过所有错误

例:下面模拟一个错误场景

环境(一个已经配置好的主从复制环境)

master数据库IP:192.168.247.128

slave数据库IP:192.168.247.130

mysql版本:5.6.14

binlog-do-db = mydb

在master上执行以下语句:

mysql>usemysql;mysql>createtablet1(idint);mysql>usemydb;mysql>insertintomysql.t1select1;

在slave上查看复制状态

mysql>showslavestatus\G***************************1.row***************************Slave_IO_State:WaitingformastertosendeventMaster_Host:192.168.247.128Master_User:replMaster_Port:3306Connect_Retry:60Master_Log_File:mysql-bin.000017Read_Master_Log_Pos:2341Relay_Log_File:DBtest1-relay-bin.000011Relay_Log_Pos:494Relay_Master_Log_File:mysql-bin.000017Slave_IO_Running:YesSlave_SQL_Running:NoReplicate_Do_DB:Replicate_Ignore_DB:Replicate_Do_Table:Replicate_Ignore_Table:Replicate_Wild_Do_Table:Replicate_Wild_Ignore_Table:Last_Errno:1146Last_Error:Error'Table'mysql.t1'doesn'texist'onquery.Defaultdatabase:'mydb'.Query:'insertintomysql.t1select1'Skip_Counter:0Exec_Master_Log_Pos:1919Relay_Log_Space:1254Until_Condition:NoneUntil_Log_File:Until_Log_Pos:0Master_SSL_Allowed:NoMaster_SSL_CA_File:Master_SSL_CA_Path:Master_SSL_Cert:Master_SSL_Cipher:Master_SSL_Key:Seconds_Behind_Master:NULLMaster_SSL_Verify_Server_Cert:NoLast_IO_Errno:0Last_IO_Error:Last_SQL_Errno:1146Last_SQL_Error:Error'Table'mysql.t1'doesn'texist'onquery.Defaultdatabase:'mydb'.Query:'insertintomysql.t1select1'Replicate_Ignore_Server_Ids:Master_Server_Id:1Master_UUID:f0f7faf6-51a8-11e3-9759-000c29eed3eaMaster_Info_File:/var/lib/mysql/master.infoSQL_Delay:0SQL_Remaining_Delay:NULLSlave_SQL_Running_State:Master_Retry_Count:86400Master_Bind:Last_IO_Error_Timestamp:Last_SQL_Error_Timestamp:13121021:37:19Master_SSL_Crl:Master_SSL_Crlpath:Retrieved_Gtid_Set:Executed_Gtid_Set:Auto_Position:01rowinset(0.00sec)

由结果可以看到,Read_Master_Log_Pos: 2341,Exec_Master_Log_Pos: 1919时出错了Last_SQL_Error: Error 'Table 'mysql.t1' doesn't exist' on query.

因为只对mydb记录了binlog,当在mydb库操作其它数据库的表,但该表在slave上又不存在时就出错了。

感谢各位的阅读!关于“mysql主从同步怎么跳过错误”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!