CentOs 7 MySql8.0.23之前的版本主从复制

准备俩台虚拟机并启动

俩台虚拟机都开启mysql后

查看二进制日志是否开启

先登录mysql

复制代码
mysql -u root -r

输入sql命令

复制代码
show variables like '%log_bin%';

如果log_bin 的value为OFF则是没有开启,跟着下面步骤开启二进制日志

退出mysql

复制代码
exit

vim /etc/my.cnf

在最底下添加

复制代码
log_bin=mysql_bin
server-id=1

效果如图

重启mysql

复制代码
systemctl restart mysqld

登录

复制代码
mysql -u root -p

查看是否开启

sql 复制代码
show variables like '%log_bin%';

随后配置第二台虚拟机也就是从库

和以上一样的配置,不同的是需要添加的server-id=2

来到主库的虚拟机进入mysql输入

sql 复制代码
show master status;

记住这查到的mysql_bin.000001和后面的154 然后切换到从库的虚拟机输入sql命令

sql 复制代码
change master to master_host='xxx.xxx.xxx.xxx',master_user='xxx',master_password='xxx',master_log_file='xxx',master_log_pos=xxx;

你需要替换此命令中的xxx

修改完后输入启动

sql 复制代码
start slave;

查看同步状态

sql 复制代码
show slave status\G

如何判断错误

第一步正确的做法第二步

第三步

如果这里显示uuid错误

进入到

sql 复制代码
cd /var/lib/mysql
sql 复制代码
vi auto.cnf

更改uuid(任意)

随后进入到mysql重新配置同上需要自行配置

sql 复制代码
change master to master_host='192.168.25.100',master_user='root',master_password='1234',master_log_file='mysql_bin.000001',master_log_pos=154;

测试

在主库中指向任意sql命令,从库中会跟着执行同样的sql命令

如在主库中输入sql命令

sql 复制代码
CREATE DATABASE db1;

然后去从库输入sql命令查看

复制代码
show databases;
相关推荐
Coder-coco5 小时前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
g***72706 小时前
【mysql】导出导入mysql表结构或者数据
数据库·mysql
屿行屿行6 小时前
【Linux】Socket编程(基于实际工程分析)
linux·服务器·网络
天才程序YUAN6 小时前
从零开始、保留 Windows 数据、安装Ubuntu 22.04 LTS双系统
linux·windows·ubuntu
Evan芙6 小时前
Rocky Linux 9 网卡改名及静态IP地址配置完整步骤
linux·网络·智能路由器
Zeku7 小时前
20251125 - 韦东山Linux第三篇笔记【上】
linux·笔记·单片机
计算机毕设小月哥7 小时前
【Hadoop+Spark+python毕设】中国租房信息可视化分析系统、计算机毕业设计、包括数据爬取、Spark、数据分析、数据可视化、Hadoop
后端·python·mysql
j***57687 小时前
【MySQL】mysqldump使用方法
数据库·mysql·oracle
企鹅侠客7 小时前
Linux性能调优 详解磁盘工作流程及性能指标
linux·运维·服务器·性能调优
icy、泡芙7 小时前
TF卡---热插拔
linux·驱动开发