• ADADADADAD

    mysql主从同步怎么跳过错误[ mysql数据库 ]

    mysql数据库 时间:2024-11-29 09:51:11

    作者:文/会员上传

    简介:

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

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    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主从同步怎么跳过错误.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysql主从同步