MySQL复制相关参数详解
MySQL复制相关参数详解
作者:尹正杰
版权声明:原创作品,谢绝转载!否则将追究法律责任。
一.复制相关系统变量
1>.server_id
是必须设置在master和每个slave上的唯一标识ID,其取值范围是1~4294967295之间,且同一个复制组之内不能重复。
2>.server_uuid
server_uuid会在GTID复制中使用。当MySQL启动之后,会首先到数据文件目录下的auto.cnf中寻找是否有指定的server_uuid,如果没有找到,则自己生成一个server_uuid并保存到这个文件中。
3>.log_slave_updates
该参数用来控制是否将收到的主库的更新数据的语句也记录在slave自己的bin log中。正常情况下是不需要记录的,但如果是想创建级联复制关系,比如A->B->C,这其中B既要作为A的从库,也要作为C的主库,则需要既开启log-bin参数,也要开启log_slave_updates参数。(开启方式:log_slave_updates=1)
4>.relay-log
该参数用来指定relay-log文件的基础名称,默认的名称为host_name-relay-bin.xxxx,其中的xxxx结尾是依次递增的数字。
5>.replicate-do-db
该参数用来指定需要复制的库。在基于语句复制的环境中,指定该参数之后,则slave的SQL thread进程只会应用在本数据库下的对象相关的语句。如果有多个数据库需要复制,则这个参数要使用多次。但如果是涉及到跨库操作语句,则复制会丢失。(指定只复制sourse数据库:replicate-do-db=course)
6>.replicate-ignore-db
该参数决定了忽略指定数据库的复制,其行为和replicate-do-db正好相反。
7>.replicate-do-table=db_name.tbl_name
通过该参数告知slave的SQL thread仅复制指定表上的数据。如果有多个表,则该参数要使用多次。
8>.replicate-wild-do-table=db_name.tbl_name
通过该参数告知SQL的SQL thread仅复制符合匹配的表,可以使用_和%作为通配符。比如replicate-wild-do-table=foo%.bar%表示复制以foo开头的数据库下所有bar开头的表数据。如果是relpicate-wild-do-table=foo%.%,则表示复制foo开头的所有表的数据,也复制CREATE/DROP/ALTER DATABASE foo开头的命令。
9>.slave-parallel-workers
该参数决定了slave上启动多少个SQL thread线程来并行应用数据的。默认值是0代表不允许并行,取值范围可以使0~1024。当数据量较大,slave和master出现数据延迟较大时,可以考虑调大改值来优化同步效率!(开启方式:slave-parallel-workers=10)
10>.skip-slave-start
该参数决定了在MySQL启动时是否先不启动slave线程,即暂停复制。(开启方式:需要在[mysqld]中指定 skip-slave-start=1)
11>.slave-parallel-type
该参数决定了当启动了并行之后,采用什么粒度的并行方式。默认值database表示按照不同的数据库执行并行,LOGICAL_CLOCK则表示按照在binlog中的一组提交的事物作为并行粒度。
12>.slave-skip-errors=[err_code1,err_code2,...|all|ddl_exist_errors]
该参数决定了当slave的SQL thread执行过程中碰到何种错误时可以忽略并继续接下来的数据复制。正常情况下,当有错误发生时,复制会停止而且需要人工干预修复才能继续进行。除非非常自信可以忽略某些错误,否则不要使用这个参数,不然会导致复制执行正常,但其实内部的数据已经完全不一致! (开启方式:slave-skip-errors=1062)
13>.sql_slave_skip_counter
代表在非GTID复制环境下,通过设置此参数来跳过复制事件。设置完该参数并非立即生效,而是等待下次start slave命令的执行生效,并将该参数再次设置为0。
14>.log-bin[=base_name]
该参数表示是否开启binary log。默认情况下MySQL会使用host_name-bin.xxxx作为文件的名字,其中xxxx是以数字递增的后缀。如果该参数指定了base_name,则二进制会以base_name.xxxx来命名。
15>.binlog-do-db=db_name
改参数决定了哪些库下的修改会被记录到bin log中。其行为与replicate-do-db类型,在基于SQL语句复制的环境下,只记录在当前数据库下的修改。比如指定binlog-do-db=course,以下语句不会记录到bin log中
mysql> USE yinzhengjie;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql>
mysql>
mysql> UPDATE course.students SET sid=sid +1000; #该语句不会被记录到bin log中
Query OK, 5 rows affected (0.01 sec)
Rows matched: 5 Changed: 5 Warnings: 0 mysql>
mysql> USE course;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql>
mysql>
mysql> UPDATE yinzhengjie.students SET sid=sid +1000; #和上面不同,该语句会记录到bin log日志中
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql>
mysql>
mysql> USE yinzhengjie;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql>
mysql> UPDATE course.students SET sid=sid +1000; #基于行复制环境下,只有属于指定数据库语句才会被记录到bin log中。 Query OK, 5 rows affected (0.00 sec)
Rows matched: 5 Changed: 5 Warnings: 0 mysql>
mysql>
mysql> USE course;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql>
mysql> UPDATE yinzhengjie.students SET sid=sid +1000; #基于行复制的话,由于指定了库进行赋值,因此该语句是不会被记录的。针对跨库的语句来说,行为和replicate-do-db相同。
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql>
mysql>
二.检查复制状态方法
1>.Slave_IO_State
代表当前slave的状态。
2>.Slave_IO_Running
代表负责读取主库bin log的IO线程是否是运行状态,正常情况下应该是YES。
3>.Slave_SQL_Running
代表负责执行备库relay log 的SQL线程是否是运行状态,正常情况下应该是YES。
4>.Last_IO_Error
代表最后一次IO线程所发生的错误,正常情况下应该是空,代表没有错误。
5>.Last_SQL_Error
代表最后一次SQL线程所发生的错误,正常情况下应该是空,代表没有错误。
6>.Seconds_Behind_Master
代表备库的SQL线程比主库的bin log晚多少秒。0代表目前没有复制延迟。
7>.Master_Log_file,Read_Master_Log_Pos
代表IO线程在主库bin log中的坐标位置。
8>.Relay_Master_Log_File,Exec_Master_Log_Pos
代表SQL线程在主库bin log中的坐标位置。
9>.Relay_Log_File,Relay_Log_Pos
表示SQL线程在备库relay log中的坐标位置。
10>.SHOW PROCESSLIST
在主库可以通过执行SHOW PROCESSLIST命令查看主库的bin log日志生成进程。
mysql> SHOW PROCESSLIST;
+----+------+-----------+--------+---------+------+----------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+------+-----------+--------+---------+------+----------+------------------+
| 3 | root | localhost | course | Query | 0 | starting | SHOW PROCESSLIST |
+----+------+-----------+--------+---------+------+----------+------------------+
1 row in set (0.00 sec) mysql>
mysql>
mysql>
mysql> SHOW PROCESSLIST\G
*************************** 1. row ***************************
Id: 3
User: root
Host: localhost
db: course
Command: Query
Time: 0
State: starting
Info: SHOW PROCESSLIST
1 row in set (0.00 sec) mysql>
mysql> SHOW PROCESSLIST\G
三.MySQL复制格式
1>.基于语句复制的优势
属于比较成熟的技术,得到广泛应用;
当SQL语句会修改很多数据时,使用语句复制会比较节省空间;
由于二进制文件中包含了所有的修改语句,所以可以用来审计功能;
2>.基于语句复制的劣势
某些特定的修改语句在基于语句复制的环境中复制会有问题,比如语句中包含自定义函数或者不确定性的存储过程;
UPDATA/DELETE语句中包含LIMIT语句但不包含ORDER BY语句数据不确定性语句;
一些函数比如RAND(),SYSDATE(),VERSION()等由于不确定性会导致复制异常;
每个导致复制异常的语句都会产生一条告警信息,比如:[Warning] Statement is not safe to log in statement format.
3>.基于行复制的优势
所有的数据库修改都可以复制,是一种安全的方式;
由于是行复制,所以某些语句在主库和从库上执行需要较少的LOCK;
4>.基于行复制的劣势
当DML语句涉及到多行的修改时,则由于行复制会把每行的修改信息都记录下来,所以bin log会很大,有可能会导致复制的延迟相比较语句复制要大;
不能直接查看备库中执行的SQL语句;
建议仅使用InnoDB表做行复制,对MyISAM表的行复制有可能会导致复制异常;
四.MySQL复制线程
1>.在slave暂停复制的方法
mysql> STOP SLAVE;
Query OK, rows affected (0.00 sec) mysql>
mysql> STOP SLAVE; #整体停止的方法
mysql> STOP SLAVE IO_THREAD;
Query OK, rows affected, warning (0.00 sec) mysql>
mysql>
mysql> STOP SLAVE IO_THREAD; #停止IO线程的方法
mysql> STOP SLAVE SQL_THREAD;
Query OK, rows affected, warning (0.00 sec) mysql>
mysql> STOP SLAVE SQL_THREAD; #停止SQL线程
2>.在slave开启复制的方法
mysql> START SLAVE;
Query OK, rows affected (0.00 sec) mysql>
mysql> START SLAVE; #整体开启的方法
mysql> START SLAVE IO_THREAD;
Query OK, rows affected, warning (0.00 sec) mysql>
mysql> START SLAVE IO_THREAD; #开启IO线程的方法
mysql> START SLAVE SQL_THREAD;
Query OK, rows affected, warning (0.00 sec) mysql>
mysql> START SLAVE SQL_THREAD; #开启SQL线程的方法
MySQL复制相关参数详解的更多相关文章
- 【DataGuard】部署Data Guard相关参数详解 (转载)
原文地址:[DataGuard]部署Data Guard相关参数详解 作者:secooler 有关物理Data Guard部署参考<[DataGuard]同一台主机实现物理Data Gua ...
- gcc与g++区别以及相关参数详解
---恢复内容开始--- 原文链接:g++和gcc的区别 一 .二者区别 gcc和g++都是GNU(一个组织)的编译器. 1.对于.c后缀的文件,gcc把它当做是C程序:g++当做是C++程序: 2. ...
- flume基本概念及相关参数详解
1.flume是分布式的日志收集系统,把手机来的数据传送到目的地去 2.flume传输的数据的基本单位是 event,如果是文本文件,通常是一行记录. event代表着一个数据流的最小完整 ...
- MySql 链接url 参数详解
最近 整理了一下网上关于MySql 链接url 参数的设置,有不正确的地方希望大家多多指教: mysql JDBC URL格式如下: jdbc:mysql://[host:port],[host:po ...
- mysql 5.6 参数详解
系统变量提供的是各种与服务器配置和功能有关的信息.大部分的系统变量都可以在服务器启动时进行设置.在运行时,每一个系统变量都拥有一个全局值或会话值,或者同时拥有这两个值.许多系统变量都是动态的,也就是说 ...
- Mysql数据库配置参数详解大全
名称 是否需要重启 值 允许值 描述 auto_increment_increment 否 1 1-65,535 auto_increment_increment和auto_increment_off ...
- 【转】MySQL my.cnf 参数 详解
[client] port = 3306 //客户端端口号为3306 socket = /tmp/mysql.sock //套接字文件(sockets),这种文件一般用在网络上的资料套 ...
- mysql 优化配置参数详解
在 my.cnf 文件中 各设置参数的含义如下: innodb_data_home_dir 这是InnoDB表的目录共用设置.如果没有在 my.cnf 进行设置,InnoDB 将使用MySQL的 da ...
- Mysql show Status参数详解
状态名 作用域 详细解释 Aborted_clients Global 由于客户端没有正确关闭连接导致客户端终止而中断的连接数 Aborted_connects Global 试图连接到MySQL服务 ...
随机推荐
- Spring Boot自动配置与Spring 条件化配置
SpringBoot自动配置 SpringBoot的自动配置是一个运行时(应用程序启动时)的过程,简化开发时间,无需浪费时间讨论具体的Spring配置,只需考虑如何利用SpringBoot的自动配置即 ...
- Elasticsearch 聚合统计与SQL聚合统计语法对比(一)
Es相比关系型数据库在数据检索方面有着极大的优势,在处理亿级数据时,可谓是毫秒级响应,我们在使用Es时不仅仅进行简单的查询,有时候会做一些数据统计与分析,如果你以前是使用的关系型数据库,那么Es的数据 ...
- 「中国剩余定理CRT」学习笔记
设正整数$m_1, m_2, ... , m_r$两两互素,对于同余方程组 $x ≡ a_1 \ (mod \ m_1)$ $x ≡ a_2 \ (mod \ m_2)$ $...$ $x ≡ a_r ...
- hdu 2955 Robberies (01背包)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2955 思路:一开始看急了,以为概率是直接相加的,wa了无数发,这道题目给的是被抓的概率,我们应该先求出总的 ...
- eclipse中git推送上传错误 没有足够的数据写入
Can't connect to any repository: https://github.com/jiashubing/test.git (https://github.com/jiashubi ...
- project 2013 显示标题
1.分析 右键只能插入任务,不能插入标题,而插入任务会被编号,目前只能在打印设置标题,不能在编辑界面显示标题的,或者使用最高级任务的方式 2.解决 文件,打印,页面设置,页眉,居中,输入标题,这样打印 ...
- Linux服务器定时健康检查,发生故障自动微信告警
此脚本适用于于各种Linux环境,可以实现各种监控项目,可自定义阀值,实现不同监控效果已在原有脚本基础上做了简化,提取了主要功能目前实现的有:1.磁盘监控2.内存监控3.cpu负荷监控4.进程数监控5 ...
- JXOI 2018 简要题解
目录 「JXOI2018」游戏 题意 题解 代码 「JXOI2018」守卫 题意 题解 代码 「JXOI2018」排序问题 题意 题解 代码 总结 「JXOI2018」游戏 题意 可怜公司有 \(n\ ...
- 【BZOJ2242】计算器(BSGS,快速幂)
[BZOJ2242]计算器(BSGS,快速幂) 题面 BZOJ 洛谷 1.给定y.z.p,计算y^z mod p 的值: 2.给定y.z.p,计算满足xy ≡z(mod p)的最小非负整数x: 3.给 ...
- [luogu1486][bzoj1503][NOI2004]郁闷的出纳员【平衡树treap】
题目描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资 ...