前言

Mysql 采用多线程进行复制是从 Mysql 5.6 开始支持的内容,但是 5.6 版本下有缺陷,虽然支持多线程,但是每个数据库只能一个线程,也就是说如果我们只有一个数据库,则主从复制时也只有一个线程在工作。相当于还是以前的单线程。 从 Mysql 5.7 开始支持同一数据库下并行主从复制。不过默认情况下,还是单数据库单个线程,如果需要使用多线程,需要在从节点进行配置。

Mysql 5.7 对主从复制增加了一种类型,共有两种类型,如下:

  • DATABASE 基于库的并行复制 , 每个数据库对应一个复制线程
  • LOGICAL_CLOCK 基于组提交的并行复制方式,同一个数据库下可以有多个线程

下面的步骤,在从节点上进行配置。

查看当前配置

在开始配置之前,我们先看一下当前配置下的主从复制的进程数。

mysql> show processlist;+----+-------------+-----------+------+---------+-------+--------------------------------------------------------+------------------+| Id | User  | Host  | db | Command | Time | State             | Info    |+----+-------------+-----------+------+---------+-------+--------------------------------------------------------+------------------+| 1 | system user |   | NULL | Connect | 91749 | Waiting for master to send event      | NULL    || 2 | system user |   | NULL | Connect | 208 | Slave has read all relay log; waiting for more updates | NULL    || 37 | root  | localhost | NULL | Query |  0 | starting            | show processlist |+----+-------------+-----------+------+---------+-------+--------------------------------------------------------+------------------+3 rows in set (0.00 sec)

下面查看复制类型和并行数量配置

mysql> show variables like 'slave_parallel_type';+---------------------+----------+| Variable_name  | Value |+---------------------+----------+| slave_parallel_type | DATABASE |+---------------------+----------+1 row in set (0.00 sec)
mysql> show variables like 'slave_parallel_workers';+------------------------+-------+| Variable_name   | Value |+------------------------+-------+| slave_parallel_workers | 0  |+------------------------+-------+1 row in set (0.01 sec)

配置多线程

1、停止从节点复制

mysql> stop slave;Query OK, 0 rows affected (0.01 sec)
mysql> set global slave_parallel_type='logical_clock';Query OK, 0 rows affected (0.00 sec)mysql> show variables like 'slave_parallel_type';+---------------------+---------------+| Variable_name  | Value   |+---------------------+---------------+| slave_parallel_type | LOGICAL_CLOCK |+---------------------+---------------+1 row in set (0.01 sec)
mysql> set global slave_parallel_workers=4;Query OK, 0 rows affected (0.00 sec)mysql> show variables like 'slave_parallel_workers';+------------------------+-------+| Variable_name   | Value |+------------------------+-------+| slave_parallel_workers | 4  |+------------------------+-------+1 row in set (0.00 sec)
mysql> start slave;Query OK, 0 rows affected (0.02 sec)
mysql> show processlist;+----+-------------+-----------+------+---------+------+--------------------------------------------------------+------------------+| Id | User  | Host  | db | Command | Time | State             | Info    |+----+-------------+-----------+------+---------+------+--------------------------------------------------------+------------------+| 37 | root  | localhost | NULL | Query | 0 | starting            | show processlist || 38 | system user |   | NULL | Connect | 8 | Waiting for master to send event      | NULL    || 39 | system user |   | NULL | Connect | 7 | Slave has read all relay log; waiting for more updates | NULL    || 40 | system user |   | NULL | Connect | 8 | Waiting for an event from Coordinator     | NULL    || 41 | system user |   | NULL | Connect | 8 | Waiting for an event from Coordinator     | NULL    || 42 | system user |   | NULL | Connect | 8 | Waiting for an event from Coordinator     | NULL    || 43 | system user |   | NULL | Connect | 8 | Waiting for an event from Coordinator     | NULL    |+----+-------------+-----------+------+---------+------+--------------------------------------------------------+------------------+7 rows in set (0.00 sec)

总结

更多相关文章

  1. Android(安卓)开机自启动程序
  2. android使用pull解析器来解析和生成xml文件
  3. android与.NET webservice
  4. Android中获取应用程序(包)的信息-----PackageManager的使用(一)
  5. Android中获取应用程序(包)的信息-----PackageManager的使用(一)
  6. Android(安卓)TimeLine 时间节点轴的实现
  7. android unity 文件读写_unity Android(安卓)打包后读取 xml 文
  8. Android(安卓)(shape,gradient)使用总结
  9. Android通过shape.xml制作渐变背景

随机推荐

  1. 读书笔记-Linux C 编程从基础到实践-第一
  2. 用GCC编译链接程序--编译链接器GCC常用功
  3. 嵌入式Linux文件系统及其存储机制分析
  4. Linux系列:linux学习之路(入门类、编程类、
  5. Oracle表按字段和|分格符导出文件
  6. 《乐者为王——自由软件Linux之父李纳斯&
  7. Shell脚本创建linux用户帐户但密码出错
  8. linux tee 命令详解
  9. 黑客常用 Linux 入侵常用命令
  10. CentOS 6.5安装配置LNMP服务器(Nginx+PHP+