主从原理:MySQL 主从同步是一种数据库复制技术,它通过将主服务器上的数据更改复制到一个或多个从服务器,实现数据的自动同步。
主从同步的核心原理是将主服务器上的二进制日志复制到从服务器,并在从服务器上执行这些日志中的操作。
主要基于MySQL二进制日志 主要包括三个线程(2个I/O线程,1个SQL线程)
data:image/s3,"s3://crabby-images/9626b/9626be9943c6e29185b06376b4edb1c4877a32a1" alt=""
1、MySQL将数据变化记录到二进制日志中;
2、Slave将MySQL的二进制日志拷贝到Slave的中继日志中;
3、Slave将中继日志中的事件在做一次,将数据变化,反应到自身(Slave)的数据库
详细步骤:
1、从库通过手工执行change master to 语句连接主库,提供了连接的用户一切条件(user 、password、port、ip),并且让从库知道,二进制日志的起点位置(file名 position 号); start slave
2、从库的IO线程和主库的dump线程建立连接。
3、从库根据change master to 语句提供的file名和position号,IO线程向主库发起binlog的请求。
4、主库dump线程根据从库的请求,将本地binlog以events的方式发给从库IO线程。
5、从库IO线程接收binlog events,并存放到本地relay-log中,传送过来的信息,会记录到master.info中
6、从库SQL线程应用relay-log,并且把应用过的记录到relay-log.info中,默认情况下,已经应用过的relay 会自动被清理purge
data:image/s3,"s3://crabby-images/07eba/07ebad027d12700c043038643e7663e72e7601a8" alt=""
本实验需要用到三台虚拟机
首先在三台虚拟机上分别:yum install -y mysql-server
方法一:基于binlog的主从同步
主库配置(虚拟机1):
vim /etc/my.cnf 写入
server_id=11
data:image/s3,"s3://crabby-images/59373/593734f4f8b6c2dd5ba95c71043e5bad8600777d" alt=""
启动服务:systemctl start mysqld
设置开机自启:systemctl enable mysqld --now
mysql> create user rep@'192.168.234.%' identified with mysql_native_password by '123456';
#identified with mysql_native_password
表示使用 mysql_native_password
认证插件来验证用户的身份。
mysql> grant replication slave on *.* to rep@'192.168.234.%'; #赋予权限
data:image/s3,"s3://crabby-images/dfd69/dfd69c47688e8ca813043e495038c4df188a3459" alt=""
++注意:show master status
是设置和维护 MySQL 主从复制的重要命令,它提供了从服务器所需的二进制日志的关键信息,帮助实现主从服务器之间的数据同步。++
++从库配置(虚拟机2):++
++vim /etc/my.cnf写入++
data:image/s3,"s3://crabby-images/e1de9/e1de9e5fffa3ef71f68286babdb026c75c557c6f" alt=""
启动服务:systemctl start mysqld
设置开机自启:systemctl enable mysqld --now
data:image/s3,"s3://crabby-images/97fa7/97fa78519e03cfc65a0248869ea9cae2fb1b2cb1" alt=""
mysql> start slave;启动从服务器
data:image/s3,"s3://crabby-images/bb3cd/bb3cd4f9ade299470f6acc6255bdb2bcc27e14bc" alt=""
虚拟机2主从配置成功!
++从库配置(虚拟机3):++
++vim /etc/my.cnf写入++
data:image/s3,"s3://crabby-images/db68c/db68c5ffa2372691b0ad11b4538313d08a9c2de2" alt=""
启动服务:systemctl start mysqld
设置开机自启:systemctl enable mysqld --now
跟上面一样的配置
data:image/s3,"s3://crabby-images/97fa7/97fa78519e03cfc65a0248869ea9cae2fb1b2cb1" alt=""
mysql> start slave;启动从服务器
data:image/s3,"s3://crabby-images/60bfb/60bfbcf558e77260df288a7158a3d729f94aee2f" alt=""
虚拟机3主从配置成功!
验证:
在主服务器(虚拟机1)上创建一个新的数据库,新的数据表
mysql> create database db1;
mysql> use db1;
mysql> create table t1(id int,name varchar(10));
mysql> insert into t1 values(1,'zhangsan'), (2,'lisi');
在从服务器(虚拟机2,虚拟机3)上查看是否同步
data:image/s3,"s3://crabby-images/0626a/0626a8e59aad6871e21c35a386387c9c25f3f5cb" alt=""
验证成功!
**方法二:**基于gtid的主从同步配置
主服务器(虚拟机1):
vim /etc/my.cnf写入
data:image/s3,"s3://crabby-images/9d37e/9d37edb2bb1efe5e5eebf73297cfac51f77a1b43" alt=""
systemctl restart mysqld.service
从服务器·(虚拟机2):
data:image/s3,"s3://crabby-images/9f150/9f1502e1e147a03d122b6796c95e81d1c74f85aa" alt=""
systemctl restart mysqld.service
mysql> stop slave; #停止slave服务·
data:image/s3,"s3://crabby-images/bcc66/bcc66b654e27467ada3fc812735a512f966881cd" alt=""
mysql> start slave;
data:image/s3,"s3://crabby-images/e40ff/e40ff4d13e21922c38182374b40916e795469c55" alt=""
主从配置成功!
从服务器·(虚拟机3):
data:image/s3,"s3://crabby-images/e36eb/e36eb5fff86f735eb535d103a8f548a87c9b39ec" alt=""
systemctl restart mysqld.service
mysql> stop slave;
data:image/s3,"s3://crabby-images/bcc66/bcc66b654e27467ada3fc812735a512f966881cd" alt=""
mysql> start slave;
data:image/s3,"s3://crabby-images/84240/842401dfb582effbe24509de6416db6d1212c4a2" alt=""
主从配置成功!
验证:
在主服务器(虚拟机1)上创建一个新的数据库,新的数据表
mysql> create database db2;
mysql> use db2;mysql> create table t2(id int,name varchar(20),year int);
mysql> insert into t2 values(1,'zhangsan',16), (2,'lisi',17),(3,'wangwu',18);
在从服务器(虚拟机2,虚拟机3)上查看是否同步
data:image/s3,"s3://crabby-images/93334/93334965fb25f93057f62941ebc076ea8e3d4866" alt=""