MySQL配置主从服务器(一主多从)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MySQL配置主从服务器(⼀主多从)⽬录
思路
主机配置
修改conf
重启
检验
从机1配置
从机2配置
配置主从关联
测试数据同步
常见问题
原因
解决⽅案
本⽂主要介绍了MySQL配置主从服务器(⼀主多从),感兴趣的可以了解⼀下
当前环境
Centos 7.6
Mysql 5.7
思路
主机配置
修改conf
vim /etc/f
在 [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;
从机1配置
修改conf
vim /etc/f
在 [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/f
在 [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 -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.请参考常见问题
测试数据同步
这⾥笔者使⽤可视化⼯具Navicat ,读者也可以使⽤其他⼯具,只是⼀个简单的测试。
在主库中新增库 test-for-repl,查看从库01、02是否有库新增
在主库 test-for-repl 新增表 test-create-table ,查看从库01、02对于库中是否有表新增在主库 test-for-repl 表 test-create-table ,查看从库01、02对于位置是否有数据
常见问题
从机查看主从同步状态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 'f'
vim /var/lib/mysql/f
systemctl restart mysqld.service
mysql -u root -p
start slave;
# \G 表⽰换⾏查看
show slave status \G;
到此这篇关于MySQL配置主从服务器(⼀主多从)的⽂章就介绍到这了,更多相关MySQL 主从服务器内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。