MySQL配置主从服务器(一主多从)

2022-05-15 0 716
目录
  • 思路
  • 主机配置
    • 修改conf
    • 重启
    • 检验
  • 从机1配置
    • 从机2配置
      • 配置主从关联
        • 测试数据同步
          • 常见问题
            • 原因
            • 解决方案

          本文主要介绍了MySQL配置主从服务器(一主多从),感兴趣的可以了解一下

          当前环境
          Centos 7.6
          Mysql 5.7

          Centos 7.6 安装MySQL 5.7 请参考:https://www.jb51.net/article/99965.htm

          思路

          MySQL配置主从服务器(一主多从)

          MySQL配置主从服务器(一主多从)

          主机配置

          修改conf

          vim /etc/my.cnf

          在 [mysqld] 后面换行追加配置,保存并退出

          server-id=1
          log-bin=master-bin
          log-bin-index=master-bin.index
          

          重启

          systemctl restart  mysqld.service
          
          # 查看状态
          systemctl status mysqld.service
          

          检验

          mysql -u root -p
          SHOW MASTER STATUS;

          MySQL配置主从服务器(一主多从)

          从机1配置

          修改conf

          vim /etc/my.cnf

          在 [mysqld] 后面换行追加配置,保存并退出

          server-id=2
          relay-log=slave-01-relay-bin
          relay-log-index=slave-01-relay-bin.index
          

          重启

          systemctl restart  mysqld.service
          # 查看状态
          systemctl status mysqld.service
          

          从机2配置

          修改conf

          vim /etc/my.cnf
          

          在 [mysqld] 后面换行追加配置,保存并退出

          server-id=3
          relay-log=slave-02-relay-bin
          relay-log-index=slave-02-relay-bin.index
          

          重启

          systemctl restart  mysqld.service
          # 查看状态
          systemctl status mysqld.service
          

          配置主从关联

          主机配置

          登录主机mysql控制台,创建用户,授权并刷新。

          mysql -u root -p
          
          CREATE USER 'repl'@'%' IDENTIFIED BY 'Mysql57*';
          GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'Mysql57*';
          flush privileges;
          

          MySQL配置主从服务器(一主多从)

          从机配置

          mysql -u root -p
          
          # 这里我的主机IP是192.168.1.8
          change master to master_host='192.168.1.8',master_port=3306,master_user='repl',master_password='Mysql57*',master_log_file='master-bin.000001',master_log_pos=0;
          
          start slave;
          #停止主从同步
          #stop slave;
          # \G 表示换行查看
          show slave status \G; 
          

          若查看主从状态提示The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.请参考常见问题

          MySQL配置主从服务器(一主多从)

          测试数据同步

          这里笔者使用可视化工具Navicat ,读者也可以使用其他工具,只是一个简单的测试。

          在主库中新增库 test-for-repl,查看从库01、02是否有库新增

          在主库 test-for-repl 新增表 test-create-table ,查看从库01、02对于库中是否有表新增在主库 test-for-repl 表 test-create-table ,查看从库01、02对于位置是否有数据

          MySQL配置主从服务器(一主多从)

          常见问题

          从机查看主从同步状态show slave status \G; 时报错

          The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.

          MySQL配置主从服务器(一主多从)

          原因

          这里笔者使用了 VMware 软件创建了1个虚拟机安装 Centos7.6 + MySQL5.7,然后使用该虚拟机克隆生成了另外两个虚拟机当从从库机器,导致3台虚拟机上的MySQL启动之后会生成相同的 UUID。

          解决方案

          找到MySQL的UUID,修改一个字符,重启服务,然后登陆MySQL控制台,开启主从

          find / -name 'auto.cnf'
          vim /var/lib/mysql/auto.cnf
          systemctl restart  mysqld.service
          mysql -u root -p
          start slave;
          # \G 表示换行查看
          show slave status \G; 
          

          到此这篇关于MySQL配置主从服务器(一主多从)的文章就介绍到这了,更多相关MySQL 主从服务器内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!

          免责声明:
          1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

          2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
          如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
          如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

          NICE源码网 MySql MySQL配置主从服务器(一主多从) https://www.niceym.com/38517.html