下載鏡像
選擇MySQL鏡像
![](/d/20211016/73ee1d0ad2f1ea620714c0029befc138.gif)
下載MySQL5.7鏡像
查看mysql鏡像
![](/d/20211016/a0bf4d4977df158c430385ffce7234de.gif)
搭建MySQL主從
master
docker run --name mysql-master -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
slave
docker run --name mysql-slave -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
Master對外映射的端口號是3307,Slave對外映射的端口號是3308
查看容器
![](/d/20211016/01f9c48eb9f07b15215428d80b97c56a.gif)
連接測試
![](/d/20211016/97431bb11caa26220aea8a547cfa4be2.gif)
![](/d/20211016/23b449057b9c34567fe6105ed6ac535a.gif)
配置Master
進(jìn)入容器 以下兩種進(jìn)入方式都可以
docker exec -it 1b166e12ad6b /bin/bash #1b166e12ad6b是容器id
docker exec -it mysql-master /bin/bash #mysql-master是容器名稱
修改/etc/mysql/my.cnf 配置文件
![](/d/20211016/bdb765186d2641c0fc9e411b30d5c87f.gif)
vim命令沒有找到 docker內(nèi)部安裝vim工具 輸入下面兩條命令安裝 vim
apt-get update
apt-get install vim
安裝完成之后 修改my.cnf 配置文件
vim /etc/mysql/my.cnf
[mysqld]
## 同一局域網(wǎng)內(nèi)注意要唯一
server-id=100
## 開啟二進(jìn)制日志功能,可以隨便取(關(guān)鍵)
log-bin=master-bin
binlog-format=ROW // 二進(jìn)制日志格式,有三種 row,statement,mixed
配置完重啟MySQL
重啟會(huì)導(dǎo)致docker容器停止,使用如下命令重新啟動(dòng)容器
![](/d/20211016/20c8a8a334822016e3cfe136958e969f.gif)
docker start mysql-master
創(chuàng)建數(shù)據(jù)庫同步賬戶
進(jìn)入mysql-master容器里面
docker exec -it 1b166e12ad6b /bin/bash
登錄到mysql中給slave主機(jī)授權(quán)同步賬號
mysql -uroot -p123456
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
![](/d/20211016/2d004fec62863c288c6b3ce4c6ddb6fb.gif)
到這master配置完成
Slave
與master相似 使用命令進(jìn)入到容器
docker exec -it mysql-slave /bin/bash
修改my.cnf配置文件 記得安裝vim命令
vim /etc/mysql/my.cnf
[mysqld]
## 設(shè)置server_id,注意要唯一
server-id=101
## 開啟二進(jìn)制日志功能,以備Slave作為其它Slave的Master時(shí)使用
log-bin=mysql-slave-bin
## relay_log配置中繼日志
relay_log=mysql-relay-bin
read_only=1 ## 設(shè)置為只讀,該項(xiàng)如果不設(shè)置,表示slave可讀可寫
重啟MySQL
啟動(dòng)容器
開啟Master-Slave主從復(fù)制
首先打開兩個(gè)終端分別進(jìn)入master和slave容器 并進(jìn)入MySQL
mysql-master操作
mysql -uroot -p123456
show master status;
![](/d/20211016/f1365df9686ac38bd3b57fabe7287e53.gif)
mysql-slave操作
注:記得把master_log_file='', master_log_pos= 改成自己在master機(jī)器上面查看的結(jié)果
mysql -uroot -p123456
change master to master_host='10.0.3.2', master_user='slave', master_password='123456', master_port=3307, master_log_file='master-bin.000001', master_log_pos=617;
start slave;
show slave status \G;
![](/d/20211016/325b6914f75e65e789d1addb0f70dda6.gif)
測試是否成功
mysql-master操作
create database dockertest;
![](/d/20211016/e6db5d25d53e82f3a1a813d22064b751.gif)
mysql-slave操作
![](/d/20211016/7d3307044cafb54080ba67c48b410a22.gif)
slave上面出現(xiàn)在master上面創(chuàng)建的數(shù)據(jù)庫證明成功。
文章參考連接
詳細(xì)介紹可參考
到此這篇關(guān)于Docker部署mysql一主一從的操作方法的文章就介紹到這了,更多相關(guān)Docker部署mysql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!