我这里是在同一台电脑上使用docker实现的主从复制,在物理机上整体思路是一致的
预备工作:安装好docker
docker pull mysql:5.7
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
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
上边两个主要的区别就是端口号和对应的文件夹不一样
/mydata/mysql-master/conf下新增文件,文件名my.cnf,其中内容为[mysqld]
log-bin=mysql-bin ##启用二进制日志
server_id=101 ## 设置server_id,同一局域网中需要唯一
这里的配置文件对应的在
/etc/my.cnf,但是因为修改该文件不方便,所以这样去新增一个文件
sudo docker restart mysql-master
REPUBLICATION和 SLAVE权限。这里创建的用户名和密码都叫xiaomingsudo docker exec -it mysql-master mysql -uroot -proot
创建用户和权限
GRANT REPLICATION SLAVE ON *.* to 'xiaoming'@'%' identified by 'xiaoming';
show master status;

此时就不要在主库做任何操作了,否则可能会变化,上图中的两个值后续会被用到。
/mydata/mysql-slave/conf下新增文件,文件名my.cnf,其中内容为[mysqld]
server_id=102 ## 设置server_id,同一局域网中需要唯一
sudo docker restart mysql-slave
登入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库会同步修改