mysql之slave_skip_errors选项

要说slave_skip_errors选项,就不得不提mysql的replication机制,总的来说它分了三步来实现mysql主从库的同步

  1. master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events);
  2. slave将master的binary log events拷贝到它的中继日志(relay log);
  3. slave重做中继日志中的事件,将改变反映它自己的数据。

但是在主从同步中会出现因为从库执行某些sql语句失败而导致主从备份关系失效,如果要修复这种失效就需要用到slave_skip_errors参数(使用sql_skip_errors_counter也是可以的)。

slave_skip_errors选项有四个可用值,分别为:off、all、ErorCode、ddl_exist_errors。

根据各个值得字面意思即可知道它们的用法,但是其中ddl_exist_errors值却比较特别,它代表了一组errorCode的组合,分别是:

1007:数据库已存在,创建数据库失败
1008:数据库不存在,删除数据库失败
1050:数据表已存在,创建数据表失败
1050:数据表不存在,删除数据表失败
1054:字段不存在,或程序文件跟数据库有冲突
1060:字段重复,导致无法插入
1061:重复键名
1068:定义了多个主键
1094:位置线程ID
1146:数据表缺失,请恢复数据库

但是还要注意的是,该值只在mysql cluster版的mysqld中才可用,而在mysql Server版的mysqld中不可用。

用到的文章:

如何查看bin-log内容:http://blog.chinaunix.net/uid-16844903-id-3896711.html

mysql主从同步原理:http://machael.blog.51cto.com/829462/239112/

mysql配置文件说明:http://www.educity.cn/shujuku/1095729.html

mysql小误区:http://dinglin.iteye.com/blog/1236330

mysql复制的几种模式:http://www.cnblogs.com/end/archive/2012/12/05/2803975.html

参考:

mysql错误代码:http://dev.mysql.com/doc/refman/5.1/en/error-messages-server.html

mysql bugs之关于ddl_exist_errors值:http://i.cnblogs.com/EditPosts.aspx?opt=1

扩展阅读:

replication常用架构:http://www.cnblogs.com/ggjucheng/archive/2012/11/13/2768879.html

理解mysql 复制(replication):http://www.cnblogs.com/hustcat/archive/2009/12/19/1627525.html

时间: 2024-10-06 05:44:17

mysql之slave_skip_errors选项的相关文章

MySQL从库选项log-slave-updates未启用引发的异常.txt

最近核查一个基于从库复制某张特定的表到另外一个主库调整,未配置log-slave-updates导致表无法正常同步.我们的配置文件中使用了replicate-rewrite-db参数以及replicate_wild_do_table参数.具体场景见下面的描述. 1.环境介绍及问题由来  DB1M(Master)  ---> DB1S(Slave)  DB2M(Master)  ---> DB2S(Slave)  现在的情形是需要将DB1M实例上的特定的表tbname上实时同步到DB2M实例  

MySQL配置优化选项

[mysqld] port                    = 3306 默认为3306 user                    = mysql datadir                 = /data/mysql 默认为/var/lib/mysql/ tmpdir                  = /dev/shm 默认为/tmp slave-load-tmpdir       = /tmp 官方文档中slave_load_tmpdir的解释:从服务器为复制LOAD D

【mysql】配置 选项文件

在Windows中,MySQL程序从以下文件读取启动选项: 文件名 目的 WINDIR\my.ini 全局选项 C:\my.cnf 全局选项 INSTALLDIR\my.ini 全局选项 defaults-extra-file 用--defaults-extra-file=path指定的文件,如果有 在Unix中,MySQL程序从下面的文件读取启动选项: 文件名 目的 /etc/my.cnf 全局选项 $MYSQL_HOME/my.cnf 服务器相关选项 defaults-extra-file

MySQL.常见表选项及约束

1.create table 选项 1.指定列选项 default.comment 2.指定表选项 engine.auto_increment.comment 2.create table 约束 1.非空约束:not null 2.唯一约束:unique 3.主键约束: primary key 4.外键:      foreign key 5.检查enum.set:chect 一.create table 选项 a. 定义列的时候,指定列选项 1.default<literal>:定义列的默认

MySQL的启动选项和系统变量该如何配置?

MySQL的配置信息可以通过两种方式实现,一种是命令行形式,在启动MySQL服务时后边带上相关配置参数,此种方式会在MySQL重启后失效.另外一种是通过写入配置文件,如my.cnf,启动或者重启MySQL服务都会生效,此种方式是永久生效. 启动选项 命令行 在MySQL服务命令启动时,带上配置参数 命令格式: 启动命令 --启动选项1[=值1] --启动选项2[=值2] ... --启动选项n[=值n] 例如: mysqld --default-storage-engine=MyISAM //设

【练习】显示MYSQL客户机选项

[[email protected] ~]$ mysql --help mysql Ver 14.14 Distrib 5.6.25, for Linux (x86_64) using EditLine wrapper Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or i

mysql my.cnf 或my.ini配置文件参数解释(转):

#*** client options 相关选项 ***# #以下选项会被MySQL客户端应用读取.注意只有MySQL附带的客户端应用程序保证可以读取这段内容.如果你想你自己的MySQL应用程序获取这些值.需要在MySQL客户端库初始化的时候指定这些选项. [client] port = 3309 socket = /usr/local/mysql/tmp/mysql.sock [mysqld] !include /usr/local/mysql/etc/mysqld.cnf #包含的配置文件

Percona Xtrabackup备份mysql (完整备份与增量备份)

Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对InnoDB和XtraDB存储引擎的数据库非阻塞地备份(对于MyISAM 的备份同样需要加表锁).XtraBackup支持所有的Percona Server.MySQL.MariaDB和Drizzle. XtraBackup优势 : 1.无需停止数据库进行InnoDB热备 2.增量备份MySQL 3.流压缩到传输到其它服务器 4.能比较容易地创建主从同步 5.备份MySQL时不会增大服务器

Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)

原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对InnoDB和XtraDB存储引擎的数据库非阻塞地备份(对于MyISAM的备份 同样需要加表锁).XtraBackup支持所有的Percona Server.MySQL.MariaDB和Drizzle. XtraBackup优势 : 1.无需停止数据库进行InnoDB热备 2.增量备份MySQL 3.流