前提声明:linux为redhat7.5,mysql为5.7.33
主机IP(Master):192.168.122.131
从机IP(Slave):192.168.122.132
mysql安装包链接和操作文档:
链接:https://pan.baidu.com/s/1dJX2NZ0Gc8fn_BQIRS8aSQ
提取码:1234
参考原文链接:https://blog.csdn.net/qq_25432245/article/details/86258924
主从备份概念:
主从备份: 就是一种主备模式的数据库应用. 主库(Master)数据与备库(Slave)数据完全一致. 实现数据的多重备份, 保证数据的安全. 可以在 Master[InnoDB]和 Slave[MyISAM]中使用不同的数据库引擎,实现读写的分离。
开始搭建
配置主机Master
1、分别在两个服务器上安装mysql,具体安装教程请参考我的另一篇博客:https://www.cnblogs.com/qcq0703/p/14290834.html
2、修改主机Master的/etc/my.cnf配置文件
vi /etc/my.cnf
添加两行代码,加以说明,server-id: MySQL 服务唯一标识,唯一标识是数字. 自然数配置的时候有要求,单机使用:server-id 任意配置,只要是数字即可,主从使用:唯一标识数字必须小于 Slave 唯一标识数字,log_bin: 日志文件命名, 开启日志功能。此日志是命令日志。就是记录主库中执行的所有的 SQL命令的。
log_bin=master_log server-id=1
如下图
3、重启主机mysql服务
service mysqld restart
4、访问数据库
/opt/install/mysql-5.7.33/bin/mysql -u root -pFwmCard@1234
5、创建slave用户,这里@后边最好用%,原文链接说是必须写从机IP但是,我写了之后,根本无法登陆,最终也无法实现主从搭建,改成%号后就没问题了。这里设置完成后,可以直接用这个slave用户登陆一下试试
grant all privileges on *.* to 'slave'@'%' identified by 'slave' with grant option;
6、刷新配置
flush privileges;
7、查看master信息,配置从机的时候要使用到以下信息的哟。需要注意了。
show master status;
从机slave配置
1、同样,修改从机mysql的配置文件
vi /etc/my.cnf
从机也添加两行代码,用于主备切换使用
server-id=2
log_bin=master_log
如下图
2、重启从机服务
service mysqld restart
3、访问从机数据库
/opt/install/mysql-5.7.33/bin/mysql -u root -pFwmCard@1234
4、配置主库信息,注意标红的啊,第一个是主机IP,最后两个标红的就是主机最后一步图片里的值,我的没对应上,那是因为我一开始的时候没有截图,在写博客的时候才进行截图,导致这些值有些改变了
change master to master_host='192.168.122.131',master_user='slave',master_password='slave',master_log_file='master_log.000001';
5、刷新配置
flush privileges;
6、启动slave,这些操作都是在mysql中操作的,不要退出去
start slave;
7、查看slave配置
show slave status G
输出结果,后面的省略了一部分,重点看标红的,那两个参数一定要是yes,就代表配置完成了。
*************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.122.131 Master_User: slave Master_Port: 3306 Connect_Retry: 60 Master_Log_File: master_log.000005 Read_Master_Log_Pos: 1440 Relay_Log_File: localhost-relay-bin.000008 Relay_Log_Pos: 1607 Relay_Master_Log_File: master_log.000005 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: .........
这里又要敲黑板了啊!!!以上操作只能实现,从机备份主机的数据!!!
想要主从自由切换,需要把从机的配置再往主机操作一遍,就实现主备自由切换!!!
主机操作的第5步,在从机配置一遍。
从机的第4步,在主机配置一遍。注意修改ip和master_log_file='master_log.000001'这两个值
设置完成后就可以互为主备,都能够操作数据库,备份数据库了。
遇到的坑,我这两个服务器是通过克隆配置的,导致mysql的UUID是一样的,上面的输出结果提示UUID重复,那么就需要设置一下auto.cnf,将里面的UUID随便写一个不一样的就可以了。
更改mysql用户的密码:
update user set authentication_string=password("slave") where user='slave';
然后刷新权限
flush privileges; #刷新权限
测试的时候,从主机修改删除一个数据库,然后查看从机的数据库是否对应修改,只要同步修改了,就代表正常了。
如果没有设置成功,需要排错的话可以参考这个链接很值得借鉴:https://blog.csdn.net/mbytes/article/details/86711508
前几天在测试主从服务器Mysql同步时遇到了从数据库显示Slave_IO_Running:Connecting; Slave_SQL_Running:Yes的问题。
下面列举几种可能的错误原因:
1.网络不通
2.账户密码错误
3.防火墙
4.mysql配置文件问题
5.连接服务器时语法
6.主服务器mysql权限
我的服务器ip:
主服务器ubuntu:192.168.16.105
从服务器ubuntu:192.168.16.115
逐项排除:
1:因为从服务器是虚拟机,网卡选择了桥接模式,ip地址确认在同一网段中,且互ping能通,排除网络问题。
2:主服务器创建了账号slave密码slave的权限账号,在主服务器可以登录slave帐号,排除帐号密码问题。
3:终端输入 sudo ufw disable 关闭防火墙, sudo ufw status查看防火墙,确认已关闭,排除防火墙原因。(sudo ufw enable打开防火墙)
4:配置文件
(1)查看主服务器配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf,看第83行:确认log_bin和server-id已经取消注释,设置无错误。
(2)查看从服务器:
此处server-id只需要与主服务器不同即可,我设置为ip的末尾数字115。确认配置无错误,排除。
5.语法:
(1)查看主服务器二进制日志信息show master status;
(2)设置从服务器链接到master主服务器,确认语句无错误,排除。
注:
master_host:主服务器Ubuntu的ip地址
master_log_file: 前面查询到的主服务器日志文件名
master_log_pos: 前面查询到的主服务器日志文件位置
change master to master_host='192.168.16.105', master_user='slave', master_password='slave',master_log_file='mysql-bin.000011', master_log_pos=154;
6.权限:
(1)主服务器查看slave帐号,已设置登录ip为%
(2)在从服务器上登录主服务器slave帐号测试:
无法登录主服务器!打开主服务器配置文件发现43行有一条绑定主机ip的语句,问题出在这里!!!给它注释掉!保存退出。重启主服务器数据库:sudo service mysql restart
(3)重新测试从服务器上登录主服务器slave帐号:登录成功!
(4)重新进入从服务器链接master主服务器,start slave开启主从同步,输入show slave status G查看从服务器状态,若开启不成功先stop slave,再start slave,可以看到Slave_IO_Runninghe和Slave_SQL_Running状态都是Yes,同步成功
主从异常解决参考链接:https://blog.csdn.net/sj349781478/article/details/79492895