MySQL配置主从服务器(一主多从)
目录
- 思路
- 主机配置
- 修改conf
- 重启
- 检验
- 从机1配置
- 从机2配置
- 配置主从关联
- 测试数据同步
- 常见问题
- 原因
- 解决方案
当前环境Centos 7.6 安装MySQL 5.7 请参考:https://www.jb51.net/article/99965.htm
Centos 7.6
Mysql 5.7
思路
文章图片
文章图片
主机配置
修改conf
vim /etc/my.cnf
在 [mysqld] 后面换行追加配置,保存并退出
server-id=1log-bin=master-binlog-bin-index=master-bin.index
重启
systemctl restartmysqld.service# 查看状态systemctl status mysqld.service
检验
mysql -u root -pSHOW MASTER STATUS;
文章图片
从机1配置 修改conf
vim /etc/my.cnf
在 [mysqld] 后面换行追加配置,保存并退出
server-id=2relay-log=slave-01-relay-binrelay-log-index=slave-01-relay-bin.index
重启
systemctl restartmysqld.service# 查看状态systemctl status mysqld.service
从机2配置 修改conf
vim /etc/my.cnf
在 [mysqld] 后面换行追加配置,保存并退出
server-id=3relay-log=slave-02-relay-binrelay-log-index=slave-02-relay-bin.index
重启
systemctl restartmysqld.service# 查看状态systemctl status mysqld.service
配置主从关联 主机配置
登录主机mysql控制台,创建用户,授权并刷新。
mysql -u root -pCREATE USER 'repl'@'%' IDENTIFIED BY 'Mysql57*'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'Mysql57*'; flush privileges;
文章图片
从机配置
mysql -u root -p# 这里我的主机IP是192.168.1.8change 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.请参考常见问题
文章图片
测试数据同步 这里笔者使用可视化工具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.
文章图片
原因
这里笔者使用了 VMware 软件创建了1个虚拟机安装 Centos7.6 + MySQL5.7,然后使用该虚拟机克隆生成了另外两个虚拟机当从从库机器,导致3台虚拟机上的MySQL启动之后会生成相同的 UUID。
解决方案
找到MySQL的UUID,修改一个字符,重启服务,然后登陆MySQL控制台,开启主从
find / -name 'auto.cnf'vim /var/lib/mysql/auto.cnfsystemctl restartmysqld.servicemysql -u root -pstart slave; # \G 表示换行查看show slave status \G;
到此这篇关于MySQL配置主从服务器(一主多从)的文章就介绍到这了,更多相关MySQL 主从服务器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- Docker应用:容器间通信与Mariadb数据库主从复制
- vue-cli|vue-cli 3.x vue.config.js 配置
- 从战略性的角度可以配置股票
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复
- mysql|InnoDB数据页结构
- mysql中视图事务索引与权限管理
- 缓存有关的配置和属性
- Spring|Spring Boot 自动配置的原理、核心注解以及利用自动配置实现了自定义 Starter 组件