文章目录
1.主从复制
1.1 概念和原理
![](https://i-blog.csdnimg.cn/direct/50082abe5d954c9c9a97ed799538d2ba.png)
![](https://i-blog.csdnimg.cn/direct/3f7df07b78c541588c0f8c219fc2d2e3.png)
1.2 案例:一主一从
1)准备工作
- 同步时间
shell
# 安装 ntpdate
yum -y install ntpdate
# 同步时间
ntpdate pool.ntp.org
# 阿里云同步时间
ntpdate ntp1.aliyun.com
- 如果是克隆的虚拟机,则需要修改 mysql 的 uuid
mysql5.6以上版本使用唯一uuid表示符,数据迁移是使用的物理备份,uuid会重复,修改uuid不一致即可
修改过后,重启 mysql 服务
![](https://i-blog.csdnimg.cn/direct/5e7428a5ca224affbdb1398e49d8bead.png)
2)master
![](https://i-blog.csdnimg.cn/direct/d22d2e895fa7447895bf7456e7e9950c.png)
![](https://i-blog.csdnimg.cn/direct/313de6cabbd64657b4918e4905679bdf.png)
shell
# 编辑 mysql 配置文件
vim /etc/my.cnf
# 写入以下内容
server-id=1
read-only=0
log-bin=mysql-bin
#binlog-do-db=my_test
# 重启服务
systemctl restart mysqld.service
![](https://i-blog.csdnimg.cn/direct/55fcd68e7e2f44ee9b3dddb40475c614.png)
shell
# 登录 mysql
mysql -uroot -p
# 创建用户,并授予主从复制权限
mysql> create user 'my'@'%' identified with mysql_native_password by 'Bdqn_8888';
mysql> grant replication slave on *.* to 'my'@'%';
# 查看主机上的binlog信息,如下图
mysql> show master status;
![](https://i-blog.csdnimg.cn/direct/edb19b92a4074fbc81698a06b145b97c.png)
3)slave
![](https://i-blog.csdnimg.cn/direct/dbd1d57748544f2abe0a3f4e88ff0fd6.png)
shell
# 编辑 mysql 配置文件
vim /etc/my.cnf
# 写入以下内容
server-id=2
read-only=1
log-bin=mysql-bin
# 重启服务
systemctl restart mysqld.service
![](https://i-blog.csdnimg.cn/direct/2fb9877b6889427194fbe3a1fc727b6c.png)
![](https://i-blog.csdnimg.cn/direct/1f287d2ed19e408dbf8fb58af2718361.png)
![](https://i-blog.csdnimg.cn/direct/08739f4496244ae3aec0d832b460a612.png)
shell
# 登录 mysql
mysql -uroot -p
# 在从机上设置主机相关信息
mysql> CHANGE MASTER TO
master_host='192.168.9.3',
master_user='my',
master_password='Bdqn_8888',
master_port=3306,
master_log_file='mysql-bin.000001',
master_log_pos=154;
#需要注意要与主机的 File 名一模一样
#master_log_file='mysql-bin.000001',
#需要注意要与主机的 Position 位置一模一样
#master_log_pos=348;
# 开启从机
mysql> START SLAVE;
# 查看状态,如下图
mysql> SHOW SLAVE STATUS\G;
![](https://i-blog.csdnimg.cn/direct/137e56815c2949eebeb23d9a7ecdd808.png)
4)测试
![](https://i-blog.csdnimg.cn/direct/1c7a0b98c659443d86a989a2af5d013d.png)
shell
# 登录mysql主机
mysql -uroot -p
# 建库建表添加数据
mysql> create database mytext;
mysql> use mytext;
mysql> create table stu(
id int(10) primary key not null auto_increment,
name varchar(50) not null,
gender char(1) not null
)engine=innodb default charset=utf8mb4;
mysql> insert into stu values (null,'tom','m'),(null,'jack','m'),(null,'marry','f');
ar(1) not null
)engine=innodb default charset=utf8mb4;
mysql> insert into stu values (null,'tom','m'),(null,'jack','m'),(null,'marry','f');