• 主主复制:主从相互授权连接,读取对方binlog日志并更新到本地数据库的过程;只要对方数据改变,自己就跟着改变。

本节介绍主主复制模式的配置。

前提条件

已安装MySQL两台服务器。服务器规划示例如表1所示。

表1 MySQL服务器规划示例

服务器名称

服务器IP

MySQL server1

10.10.10.31

MySQL server2

10.10.10.32

操作步骤

  1. 以root用户登录MySQL server1。
  2. 配置MySQL server1的my.cnf文件。
    1. 执行以下命令,编辑配置文件。

      # vi /etc/my.cnf

    2. 在[mysqld]部分添加下面加黑参数。其中,“bind-address”参数请修改为MySQL服务器的地址。
      说明:

      本步骤中的参数为新增,请保留3.b.i步骤中的其他配置参数。

      #主标服务标识号,必需唯一
      server-id = 1
      # the bind ip
      bind-address = 10.10.10.30 #log_bin日志名称格式:${datadir}/mysql-bin.0000*
      log_bin = mysql-bin
      log_bin_trust_function_creators=1 #日志内容记录格式
      binlog_format = mixed #不建议使用这种配置,如果跨域操作会出现同步异常。
      # binlog_do_db = dbname
      # binlog_ignore_db = dbname #设置需要同步的数据库名,多个数据库时配置多次该语句。
      replicate-wild-do-table=apigwdb.%
      replicate-wild-do-table=apimarkdb.%
      replicate-wild-do-table=livedata.%
      replicate-wild-do-table=mqs_web.%
      replicate-wild-do-table=iot_web.%
      replicate-wild-do-table=roma_fdi_prod.%
      replicate-wild-do-table=roma_quartz.%
      replicate-wild-do-table=roma_web.%
      replicate-wild-do-table=roma_config. log-slave-updates #经过1日志写操作就把日志文件写入硬盘一次(对日志信息进行一次同步)。n=1是最安全的做法,但效率最低。默认设置是n=0。
      sync_binlog = 1 #auto_increment_offset=1设置步长,这里设置为1,这样Master的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID
      auto_increment_offset = 1 #auto_increment_increment=n有多少台服务器,n就设置为多少
      auto_increment_increment = 2 #忽略所有复制产生的错误
      slave-skip-errors = all
      说明:

      replicate-wild-do-table参数的配置请参考表9

    3. 修改完成后,执行:wq! 保存退出。
    4. 重启MySQL。

      # cd /opt/mysql/support-files

      # mysql.server stop

      # mysql.server start

    5. 查看MySQL状态。

      # mysql.server status

  3. 以root用户登录MySQL server2。
  4. 配置MySQL server2的my.cnf文件。
    1. 执行以下命令,编辑配置文件。

      # vi /etc/my.cnf

    2. 在[mysqld]部分添加下面加黑参数。其中,“bind-address”参数请修改为MySQL服务器的地址。
      说明:

      本步骤中的参数为新增,请保留3.b.i步骤中的其他配置参数。

      #主标服务标识号,必需唯一(区别于server11)
      server-id = 2 # the bind ip
      bind-address = 10.10.10.31 #log_bin日志名称格式:${datadir}/mysql-bin.0000*
      log_bin = mysql-bin
      log_bin_trust_function_creators=1 #日志内容记录格式
      binlog_format = mixed #不建议适用这种配置,如果跨域操作会出现同步异常。
      # binlog_do_db = dbname
      # binlog_ignore_db = dbname #设置需要同步的数据库名,多个数据库时配置多次该语句。
      replicate-wild-do-table=apigwdb.%
      replicate-wild-do-table=apimarkdb.%
      replicate-wild-do-table=livedata.%
      replicate-wild-do-table=mqs_web.%
      replicate-wild-do-table=iot_web.%
      replicate-wild-do-table=roma_fdi_prod.%
      replicate-wild-do-table=roma_quartz.%
      replicate-wild-do-table=roma_web.%
      replicate-wild-do-table=roma_config.% log-slave-updates #经过1日志写操作就把日志文件写入硬盘一次(对日志信息进行一次同步)。n=1是最安全的做法,但效率最低。默认设置是n=0。
      sync_binlog = 1 #auto_increment_offset=1设置步长,这里设置为2,这样Master的auto_increment字段产生的数值是:2,4,6,8 …等偶数ID
      auto_increment_offset = 2 #auto_increment_increment=n有多少台服务器,n就设置为多少,
      auto_increment_increment = 2 #忽略所有复制产生的错误
      slave-skip-errors = all
    3. 修改完成后,执行:wq! 保存退出。
    4. 重启MySQL。

      # cd /opt/mysql/support-files

      # mysql.server stop

      # mysql.server start

    5. 查看MySQL状态。

      # mysql.server status

  5. 设置MySQL server2同步更新MySQL server1。
    1. 以root用户登录MySQL server1。
    2. 进入MySQL控制台。

      # cd /opt/mysql/bin

      # mysql -u root -p

      按照提示信息输入待连接的MySQL服务器的数据库root用户的密码:

      Enter Password:

      登录成功后系统显示如下类似信息:

      Enter password:
      Welcome to the MySQL monitor. Commands end with ; or \g.
      Your MySQL connection id is 4381
      Server version: 5.7.24-enterprise-commercial-advanced MySQL Enterprise Server - Advanced Edition (Commercial) Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
      affiliates. Other names may be trademarks of their respective
      owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
      mysql>
    3. 锁MySQL server1表。

      mysql> flush tables with read lock;

    4. 查看MySQL server1状态。

      mysql> show master status;

      系统显示如下类似信息:

      +---------------+----------+--------------+------------------+------------------------------------------------+
      | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
      +---------------+----------+--------------+------------------+------------------------------------------------+
      | binlog.000004 | 194 | test | mysql | 39380c8b-aa71-11e8-8dc6-286ed488ec36:1-3319087 |
      +---------------+----------+--------------+------------------+------------------------------------------------+
      1 row in set (0.00 sec)
    5. 以root用户登录MySQL server2。
    6. 进入MySQL控制台。

      # cd /opt/mysql/bin

      # mysql -u root -p

      按照提示信息输入待连接的MySQL服务器的数据库root用户的密码:

      Enter Password:
    7. 停止slave同步进程。

      mysql> stop slave;

    8. 执行同步语句。

      mysql> change master to master_host='10.10.10.31',master_user='root',master_password='Password',master_log_file='binlog.000004' ,master_log_pos=194;

      其中,

      • master_host设置为MySQL Server1的地址。
      • master_user设置为同步用户名,此处使用root用户。
      • master_password设置为同步用户密码。
      • master_log_file设置为MySQL Server1的show master status;命令执行结果File列的值。
      • master_log_pos设置为MySQL Server1的show master status;命令执行结果Position列的值。
    9. 开启slave同步进程。

      mysql> start slave;

    10. 查看slave同步信息

      mysql> show slave status\G;

      ...
      Slave_IO_Running:Yes
      Slave_SQL_Running:Yes
      ...

      若显示信息中以上两个参数为yes,即说明配置成功。

  6. 设置server1同步更新server2,步骤与5类似。
  7. 分别在MySQL Server1和MySQL Server2的控制台执行以下命令,解锁数据库表。

    mysql> unlock tables;

  8. 检测数据库主主同步是否设置成功。

    在任意MySQL创建数据库并创建表,插入数据,在另一MySQL查看是否同步成功。

Linux下MySQL主主同步的更多相关文章

  1. Linux下MySQL数据库主从同步配置

    说明: 操作系统:CentOS 5.x 64位 MySQL数据库版本:mysql-5.5.35 MySQL主服务器:192.168.21.128 MySQL从服务器:192.168.21.129 准备 ...

  2. Linux下 MYSQL 主从复制、同步

    mysql从3.23.15版本以后提供数据库复制功能.利用该功能可以实现两个数据库同步,主从模式(A->B),互相备份模式(A<=>B)的功能. 主从模式(A->B)的配置过程 ...

  3. linux下MySQL安装登录及操作

    linux下MySQL安装登录及操作 二.安装Mysql 1.下载MySQL的安装文件 安装MySQL需要下面两个文件: MySQL-server-4.0.16-0.i386.rpm MySQL-cl ...

  4. Linux下MySQL/MariaDB Galera集群搭建过程【转】

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  5. linux下mysql设置主从

    一  主服务器修改 mysql的主从设置主要原理是 主数据库开启日志,并且创建从服务器专属账户,从服务器用该账户,读取到日志进行同步 准备两个mysql数据库(如何安装请查看,linux下mysql安 ...

  6. linux下mysql基于mycat做主从复制和读写分离之基础篇

    Linux下mysql基于mycat实现主从复制和读写分离1.基础设施 两台虚拟机:172.20.79.232(主) 172.20.79.233(从) 1.1软件设施 mysql5.6.39 , my ...

  7. .Neter玩转Linux系列之六:Linux下MySQL的安装、配置、使用

    一.Linux安装MySQL (1)下载安装包:https://dev.mysql.com/downloads/mysql/ (2)解压并安装 命令:tar zxvf 文件名 解压完成之后,重名一下文 ...

  8. Linux下mysql的常用操作

    Linux下mysql的常用操作: 显示数据库 show databases; 选择数据库 use 数据库名; 显示数据库中的表 show tables; 显示数据表的结构 describe 表名; ...

  9. Linux下MySQL的简单操作

    Linux下MySQL的简单操作 更改mysql数据库root的密码 首次进入数据库是不用密码的: [root@localhost ~]# /usr/local/mysql/bin/mysql -ur ...

  10. windows下mysql和linux下mysql主从配置

    1. linux下mysql安装版本5.6   windows下mysql版本5.7  不要问我为什么版本不一致  就是想这么搞 2. linux为主服务器   windows为从服务器 3.找到li ...

随机推荐

  1. 吴裕雄--天生自然 PHP开发学习:PhpStorm的配置与安装

    下载安装包

  2. 视频播放插件JWPlayer的使用

      JwPlayer  简介   JW Media Player是一个开源的在网页上使用的Flash视频.音频以及图片播放器,支持 Sliverlight 播放,支持H.264 ( .mp4, .mo ...

  3. Google在百慕大避税几十亿美金,为什么巨头和富豪都会选百慕大避税?

    为什么"越有钱越有钱"?为什么富豪只要不自己"作",就能让自己的财富疯狂增加?除了经营意识之外,关键他们还可以利用自己的资源.实力等去做很多看似让人不齿,但其实 ...

  4. 机器CPU load过高问题排查

    load average的概念 系统平均负载定义:在特定时间间隔内运行队列中(在CPU上运行或者等待运行多少进程)的平均进程数.如果一个进程满足以下条件则其就会位于运行队列中: 它没有在等待I/O操作 ...

  5. Scheme实现数字电路仿真(3)——模块

    版权申明:本文为博主窗户(Colin Cai)原创,欢迎转帖.如要转贴,必须注明原文网址 http://www.cnblogs.com/Colin-Cai/p/12242650.html 作者:窗户 ...

  6. Python——2list和tuple类型

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  7. 记一次crontab执行和日志生成问题

    一.crontab未执行 crontab里面设置定时任务如下: 1 19 * * * /usr/bin/python3 /home/nola/a.py > /home/nola/logs/a_l ...

  8. golang在debian下不能用sudo进行使用的问题

    sudo ln -s /usr/local/go/bin/go /usr/bin/go 然后就ok了. 去查了下这两个路径的差别,也没查出什么.只是说/usr/bin 是系统预装所在的路径.

  9. java反序列化-ysoserial-调试分析总结篇(5)

    前言: 这篇文章继续分析commonscollections5,由如下调用链可以看到此时最外层的类不是annotationinvoke,也不是priorityqueue了,变成了badattribut ...

  10. 7-1 jmu-python-汇率兑换 (10 分)

    7-1 jmu-python-汇率兑换 (10 分)   按照1美元=6人民币的汇率编写一个美元和人民币的双向兑换程序 输入格式: 输入人民币或美元的金额,人民币格式如:R100,美元格式如:$100 ...