Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > Mysql主从复制部署

Mysql主从复制部署过程解读

作者:杨了个杨8982

MySQL主从复制通过GTID实现主数据库变更同步到从数据库,适用于读写分离、高可用性和数据备份,配置步骤包括环境准备、主从服务器配置、其他配置等

MySQL 主从复制是将主数据库的变更自动同步到从数据库的过程,常用语读写分离、高可用性和数据备份。

GTID(全局事务标识符)是 MySQL 5.6 引入的特性,用于唯一标识每一个事务。

在主从复制中使用 GTID 可以简化复制配置,提高可靠性,避免传统复制中常见的位点偏移问题。

1.环境准备

确保主从服务器已安装相同版本的 MySQL,并能通过网络互相访问。

# 检查 MySQL 版本
mysql -V

2.配置主服务器

(1)编辑主服务器的配置文件(通常是 /etc/my.cnf 或 /etc/mysql/mysql.conf.d/mysqld.cnf)

[mysqld]
server-id = 1                 # 唯一标识,建议使用IP地址的最后一个数
log-bin = mysql-bin           # 启用二进制日志
gtid_mode = ON
enforce_gtid_consistency = ON
log_slave_updates = ON
binlog_format = ROW

(2)重启 MySQL 服务并验证配置

sudo systemctl restart mysql
mysql -e "SHOW VARIABLES LIKE 'gtid_mode';"  # 应显示 ON
mysql -e "SHOW VARIABLES LIKE 'enforce_gtid_consistency';"  # 应显示 ON

(3)创建复制用户

CREATE USER 'repl_user'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'%';
FLUSH PRIVILEGES;

3.配置从服务器

(1)编辑从服务器的配置文件

[mysqld]
server-id = 2                 # 唯一标识,不能与主库重复
log-bin = mysql-bin           # 启用二进制日志
read-only = 1                 # 从库设置为只读(可选)
gtid_mode = ON
enforce_gtid_consistency = ON
log_slave_updates = ON
binlog_format = ROW

(2)重启 MySQL 服务

sudo systemctl restart mysql

(3)连接从服务器到主服务器

在从服务器上执行以下命令,配置主从关系:
CHANGE MASTER TO
MASTER_HOST='主服务器IP',
MASTER_USER='repl_user',
MASTER_PASSWORD='password',
MASTER_AUTO_POSITION = 1;  # 使用 GTID 自动定位

START SLAVE;

SHOW SLAVE STATUS\G;    #检查 IO 和 SQL 线程状态,确认从服务器是否落后于主服务器
检查以下两个状态是否均为 Yes:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Seconds_Behind_Master: 0

4.其他配置

(1)MySQL 启用安全连接(MySQL 8.0)

# step 1 在主库和从库生成 SSL 证书
# 在主库和从库分别执行(使用相同的 CA)
mkdir /etc/mysql/ssl && cd /etc/mysql/ssl
openssl genrsa 2048 > ca-key.pem
openssl req -new -x509 -nodes -days 3650 -key ca-key.pem -out ca.pem
openssl req -newkey rsa:2048 -days 3650 -nodes -keyout server-key.pem -out server-csr.pem
openssl x509 -req -in server-csr.pem -days 3650 -CA ca.pem -CAkey ca-key.pem -set_serial 01 -out server-cert.pem

# step 2 配置主库 my.cnf
[mysqld]
ssl-ca=/etc/mysql/ssl/ca.pem
ssl-cert=/etc/mysql/ssl/server-cert.pem
ssl-key=/etc/mysql/ssl/server-key.pem

# step 3 配置从库 my.cnf
[mysqld]
ssl-ca=/etc/mysql/ssl/ca.pem
ssl-cert=/etc/mysql/ssl/server-cert.pem
ssl-key=/etc/mysql/ssl/server-key.pem

# step 4 重启主从库服务
systemctl restart mysql

# step 5 创建用户
# 创建使用旧认证方式的复制用户
-- 在主库执行
CREATE USER 'repl_user'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'%';
FLUSH PRIVILEGES;

# 修改 MySQL 用户认证方式
ALTER USER 'yang'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password';
FLUSH PRIVILEGES;

(2)禁用主库的 SSL 要求

[mysqld]
require_secure_transport = OFF  # 关闭强制 SSL

(3) 传统方式配置主从

-- 从库执行
CHANGE MASTER TO
  MASTER_HOST='主库IP',
  MASTER_USER='repl_user',
  MASTER_PASSWORD='password',
  MASTER_PORT=3306,
  MASTER_LOG_FILE='主库binlog文件',
  MASTER_LOG_POS=主库binlog位置;
START SLAVE;

(4)其他命令

stop slave;        #停止复制从库
reset slave;        #删除从库配置
reset master;        #删除主库配置
SHOW MASTER STATUS;    #查询当前主库的 binlog 文件和位置

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文