我这里是在同一台电脑上使用docker实现的主从复制,在物理机上整体思路是一致的
预备工作:安装好docker
使用docker运行MySQL
- 拉取MySQL镜像
docker pull mysql:5.7
- 运行mysql master容器
sudo docker run -p 33061:3306 --name mysql-master-v /mydata/mysql-master/conf:/etc/mysql/conf.d -v /mydata/mysql-master/logs:/logs -v /mydata/mysql-master/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
- 运行mysql slave 容器
sudo docker run -p 33062:3306 --name mysql-slave -v /mydata/mysql-slave/conf:/etc/mysql/conf.d -v /mydata/mysql-slave/logs:/logs -v /mydata/mysql-slave/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
上边两个主要的区别就是端口号和对应的文件夹不一样
配置mysql master
- 在目录
/mydata/mysql-master/conf
下新增文件,文件名my.cnf
,其中内容为
[mysqld]
log-bin=mysql-bin ##启用二进制日志
server_id=101 ## 设置server_id,同一局域网中需要唯一
这里的配置文件对应的在
/etc/my.cnf
,但是因为修改该文件不方便,所以这样去新增一个文件
- 然后重启mysql master
sudo docker restart mysql-master
- 创建用户并赋予
REPUBLICATION
和SLAVE
权限。这里创建的用户名和密码都叫xiaoming
进入mysql
sudo docker exec -it mysql-master mysql -uroot -proot
创建用户和权限
GRANT REPLICATION SLAVE ON *.* to 'xiaoming'@'%' identified by 'xiaoming';
- 查看master状态
show master status;
此时就不要在主库做任何操作了,否则可能会变化,上图中的两个值后续会被用到。
配置mysql slave
- 在目录
/mydata/mysql-slave/conf
下新增文件,文件名my.cnf
,其中内容为
[mysqld]
server_id=102 ## 设置server_id,同一局域网中需要唯一
- 重启mysql slave
sudo docker restart mysql-slave
- 配置mysql master的数据
登入mysql
sudo docker exec -it mysql-slave mysql -uroot -proot
设置master,其中的mysql_log_file
和master_log_pos
就是配置master时的那两个值
change master to master_host='192.168.0.100',master_port=33061,master_user='xiaoming',master_password='xiaoming',master_log_file='mysql-bin.000001',master_log_pos=441;
- 开启同步
start slave;
- 查看状态
show slave status;
或使用下列命令竖排查看
show slave status\G;
此时Slave_IO_Running
和Slave_SQL_Running
应都为Yes
,说明设置成功
此时对master库进行修改,slave库会同步修改