本文实践了用Docker方式来实现基于binlog的MySql主从复制。关于MySql主从复制的原理将在下一篇中进行讲解。
一些数据的本地存储目录结构
mysql >tree -L 2
.
├── data
│ ├── master01
│ └── slave01
├── master01
│ └── master01.cnf
└── slave01
└── slave01.cnfmaster01.cnf配置
[mysqld]log-bin=mysql-master01-bin # 使用binary logging,mysql-master01-bin是log文件名的前缀
server-id=1 # 唯一服务器ID,非0整数,不能和其他服务器的server-id重复slave01.cnf配置
[mysqld]log-bin=mysql-slave01-bin
server-id=2 创建master01容器
docker run -d –name master01 -v /Users/craneyuan/backup/docker/mysql/data/master01:/var/lib/mysql -v /Users/craneyuan/backup/docker/mysql/master01:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 -p 3307:3306 mysql:5.7
注意:启动容器的时候不要立刻就去连接数据库,会造成一些莫名奇妙的问题,比如连不上,可以将数据都删掉然后restart容器。
创建slave01容器
docker run -d –name slave01 -v /Users/craneyuan/backup/docker/mysql/data/slave01:/var/lib/mysql -v /Users/craneyuan/backup/docker/mysql/slave01:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 -p 3308:3306 mysql:5.7
在master01中添加复制用户
SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));GRANT REPLICATION SLAVE ON *.* to 'backup'@'%' identified by '123456';
show master status; # 查看master的状态
在slave01中配置与master01相关的内容
SET sql_mode=(SELECT REPLACE(@@sql_mode,’ONLY_FULL_GROUP_BY’,”));
change master to master_host='192.168.10.223',master_port=3307,master_user='backup',master_password='123456',master_log_file='mysql-master01-bin.000003', master_log_pos=154;master_host是宿主机的IP(ifconfig查到的操作系统IP,不是容器的IP,一定不能搞错)
master_port是主服务器的映射到3306的端口(默认3306)
master_user为创建的备份用户
master_password备份用户的密码
master_log_file和master_log_pos则是show master status列表里面的两个值,分别是mysql日志名和起始备份位置
启动slave(依然在slave01中操作)
start slave;
show slave status; 或者show slave statusG;如果是Waiting for master to send event则说明主从复制成功了,若是Connecting to master肯定是配置错误,楼主就错了几次,重删除配置一下就行,这就是容器的好处,删除的代价很小,短时间就可以恢复。如果是Waiting for master to send event,对主库的增删改查从库都会同步修改。










