开发者社区> code-x> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

MySQL主从复制搭建

简介: MySQL主从复制搭建
+关注继续查看

master

docker run  -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 --network rootnet --ip 172.18.0.10 -v /usr/soft/mysql-master/data:/var/lib/mysql:rw -v /usr/soft/mysql-master/log:/var/log/mysql:rw -v /usr/soft/mysql-master/config/my.cnf:/etc/mysql/my.cnf:rw -v /etc/localtime:/etc/localtime:ro --name mysql8-master -d mysql


my.cnf

###主数据库配置
[mysqld]
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
datadir         = /var/lib/mysql
secure-file-priv= NULL
# Custom config should go here
!includedir /etc/mysql/conf.d/
default_authentication_plugin= mysql_native_password
# 主从同步设置
# 设置同步的binary log二进制日志文件名前缀, 默认为binlog; 在MySQL 8.0中, 无论是否指定--log bin选项, 默认情况下都会启用二进制日志记录, 并将log_bin系统变量设置为ON
log-bin=mysql-bin
# 服务器唯一id,默认为1,值范围为1~2^32−1. 主数据库和从数据库的server-id不能重复
server-id=1
###可选配置
# 需要主从复制的数据库,如多个则重复配置
binlog-do-db=test
# 复制过滤:也就是指定哪个数据库不用同步(mysql库一般不同步),如多个则重复配置
binlog-ignore-db=mysql
# 为每个session分配的内存,在事务过程中用来存储二进制日志的缓存
binlog_cache_size=1M
# 主从复制的格式(mixed, statement, row 默认格式是statement. 建议是设置为row, 主从复制时数据更加能够统一)
binlog_format=row
# 配置二进制日志自动删除/过期时间,单位秒,默认值为2592000,即30天; 8.0.3版本之前使用expire_logs_days, 单位天数,默认值为0, 表示不自动删除.
binlog_expire_logs_seconds=2592000
# 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断,默认OFF关闭,可选值有OFF、all、ddl_exist_errors以及错误码列表。8.0.26版本之前使用slave_skip_errors
# 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062


创建用户

CREATE USER 'repl'@'172.18.0.11' IDENTIFIED BY '123456';

授权

GRANT REPLICATION SLAVE ON . TO 'repl'@'172.18.0.11';

slave

docker run  -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456  --network rootnet --ip 172.18.0.11  -v /usr/soft/mysql-slave/data:/var/lib/mysql:rw -v /usr/soft/mysql-slave/log:/var/log/mysql:rw -v /usr/soft/mysql-slave/config/my.cnf:/etc/mysql/my.cnf:rw -v /etc/localtime:/etc/localtime:ro --name mysql8-slave -d mysql


mf.cnf

###主从数据库配置核心部分
[mysqld]
# 设置同步的binary log二进制日志文件名前缀,默认是binlog
log-bin=mysql-bin
# 服务器唯一id,默认为1,值范围为1~2^32−1. ;主数据库和从数据库的server-id不能重复
server-id=2
###可选配置
# 需要主从复制的数据库 ,如多个则重复配置
replicate-do-db=test
# 复制过滤:也就是指定哪个数据库不用同步(mysql库一般不同步) ,如多个则重复配置
binlog-ignore-db=mysql
# 为每个session分配的内存,在事务过程中用来存储二进制日志的缓存 
binlog_cache_size=1M
# 主从复制的格式(mixed,statement,row,默认格式是statement。建议是设置为row,主从复制时数据更加能够统一) 
binlog_format=row
# 配置二进制日志自动删除/过期时间,单位秒,默认值为2592000,即30天;8.0.3版本之前使用expire_logs_days,单位天数,默认值为0,表示不自动删除。
binlog_expire_logs_seconds=2592000
# 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断,默认OFF关闭,可选值有OFF、all、ddl_exist_errors以及错误码列表。8.0.26版本之前使用slave_skip_errors
# 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
replica_skip_errors=1062
# relay_log配置中继日志,默认采用 主机名-relay-bin 的方式保存日志文件 
relay_log=replicas-mysql-relay-bin  
# log_replica_updates表示slave是否将复制事件写进自己的二进制日志,默认值ON开启;8.0.26版本之前使用log_slave_updates
log_slave_updates=ON
# 防止改变数据(只读操作,除了特殊的线程)
read_only=ON


开启

SHOW MASTER STATUS;


CHANGE REPLICATION SOURCE TO SOURCE_HOST='172.18.0.10', SOURCE_PORT=3306, SOURCE_USER='repl', SOURCE_PASSWORD='123456', SOURCE_LOG_FILE='mysql-bin.000001', SOURCE_LOG_POS=2704;


## 开启
START REPLICA;
## 关闭
STOP REPLICA;


SHOW REPLICA STATUS;

假如显示 Slave_IO_Running/Replica_IO_Running和Slave_SQL_Running/Replica_SQL_Running 为 Yes

以及Slave_IO_State/Replica_IO_State 为 Waiting for master to send event/Waiting for source to send event

则证明主从复制成功

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
mysql主从复制
mysql主从复制笔记,以及binlog的三种模式的区别
52 0
【MySql】主从复制
MySQL支持单向、异步复制,复制过程中一个Linux服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护日志文件的一个索引以跟踪日志循环。
772 0
+关注
14
文章
1
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载