1. 搭建MySQL主从
1.1. 准备主服务器
-
创建一个主节点MySQL
docker run -itd \ -p 3307:3307 \ -v /container/volumes/mysql-master/conf:/etc/mysql/conf.d \ -e MYSQL_ROOT_PASSWORD=123456a \ -e MYSQL_ROOT_HOST='%' \ --name=mysql-master \ mysql:8.0.23
-
修改主节点的配置文件
vim /container/volumes/mysql-master/conf/my.cnf
[mysqld] # 服务端口号,默认3306 port=3307 # 服务器唯一id,默认值1 server-id=1 # 设置日志的格式,默认是ROW binlog_format=STATEMENT # 二进制日志名,默认binlog #log-bin=binlog # 设置需要复制的数据库,默认复制全部数据库 #binlog-do-db=testdb # 设置不需要复制的数据库 #binlog-ignore-db=mysql #binlog-ignore-db=information_schema
-
重启MySQL主节点
docker restart mysql-master
-
创建一个用户用于主从复制
-- 创建用户 CREATE USER 'slave'@'%' IDENTIFIED BY '123456a'; -- 授予用户复制权限 GRANT replication SLAVE ON *.* TO 'slave'@'%' WITH GRANT OPTION; -- 刷新权限 FLUSH PRIVILEGES;
-
查看主节点的状态
show master status;
记录
File
和Position
的值。
📝
binlog_format
可选值:
- STATEMENT:日志记录的是主数据库的
写命令
,性能高,但是now()之类的函数以及获取系统参数的操作会出现主从数据不同步的情况- ROW(默认):日志记录的是主数据库的
写后的数据
,批量操作时性能较差,解决now()、user()或@@hostname等操作主从机器上不一致的问题- MIXED:以上两种模式混合使用。有函数用
ROW
,没函数用STATEMENT
,但是无法识别系统变量
1.2. 准备从服务器
-
创建一个从节点MySQL
docker run -itd \ -p 3308:3308 \ -v /container/volumes/mysql-slave1/conf:/etc/mysql/conf.d \ -e MYSQL_ROOT_PASSWORD=123456a \ -e MYSQL_ROOT_HOST='%' \ --name=mysql-slave1 \ mysql:8.0.23
-
修改主节点的配置文件
vim /container/volumes/mysql-slave1/conf/my.cnf
[mysqld] # 服务端口号,默认3306 port=3308 # 服务器唯一id,默认值1 server-id=2 # 中继日志名,默认xxxx-relay-bin #relay-log=relay-bin
-
重启MySQL从节点
docker restart mysql-slave1
-
配置主从关系
⚠️需要在从节点的MySQL上执行
CHANGE MASTER TO master_host = '192.168.5.20', master_user = "slave", master_password = "123456a", master_port = 3307, master_log_file = "binlog.000003", master_log_pos = 1985;
-
重复执行上述步骤,创建slave2节点
1.3. 启动主从
启动从节点的复制功能,执行SQL:
start slave;
-- 查看状态
show slave status;
1.4. 测试主从数据同步
DROP DATABASE IF EXISTS db_user;
CREATE DATABASE db_user;
USE db_user;
CREATE TABLE t_user (
id BIGINT UNSIGNED PRIMARY KEY auto_increment COMMENT 'id',
username VARCHAR (32) NOT NULL COMMENT '用户名',
gender TINYINT UNSIGNED NOT NULL COMMENT '性别(0 女 1 男)'
);
INSERT INTO t_user ( username, gender )
VALUES
(
'张三',
1);
INSERT INTO t_user ( username, gender )
VALUES
(
@@hostname,
0);
在主节点执行以上sql,去从节点是否可以从主节点同步数据
1.5. 停止和重置
-- 停止I/O线程和SQL线程的操作
stop slave;
-- 删除slave数据库的relaylog日志文件,并重新启用新的relaylog文件
reset slave;
-- 删除所有binlog日志文件,并将日志索引文件清空,重新开始所有新的日志文件。
-- 用于第一次进行搭建主从数据库时,进行binlog初始化工作
reset master;