Docker部署mysql一主一從的操作方法
下載鏡像
選擇MySQL鏡像
docker search mysql

下載MySQL5.7鏡像
docker pull mysql:5.7
查看mysql鏡像
docker images

搭建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
查看容器
docker ps

連接測試


配置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 配置文件
vim /etc/mysql/my.cnf

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)制日志功能,可以隨便?。P(guān)鍵) log-bin=master-bin binlog-format=ROW // 二進(jìn)制日志格式,有三種 row,statement,mixed
配置完重啟MySQL
service mysql restart
重啟會導(dǎo)致docker容器停止,使用如下命令重新啟動容器
docker ps -a

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'@'%';

到這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時使用 log-bin=mysql-slave-bin ## relay_log配置中繼日志 relay_log=mysql-relay-bin read_only=1 ## 設(shè)置為只讀,該項如果不設(shè)置,表示slave可讀可寫
重啟MySQL
service mysql restart
啟動容器
docker start mysql-slave
開啟Master-Slave主從復(fù)制
首先打開兩個終端分別進(jìn)入master和slave容器 并進(jìn)入MySQL
mysql-master操作
mysql -uroot -p123456 show master status;

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;

測試是否成功
mysql-master操作
create database dockertest;

mysql-slave操作

slave上面出現(xiàn)在master上面創(chuàng)建的數(shù)據(jù)庫證明成功。
文章參考連接
到此這篇關(guān)于Docker部署mysql一主一從的操作方法的文章就介紹到這了,更多相關(guān)Docker部署mysql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
docker部署管理工具portainer-ce的實(shí)現(xiàn)
Portainer是一個可視化的容器鏡像的圖形管理工具,利用Portainer可以輕松構(gòu)建,管理和維護(hù)Docker環(huán)境,本文主要介紹了docker部署管理工具portainer-ce的實(shí)現(xiàn),感興趣的可以了解一下2023-08-08
Docker部署HertzBeat實(shí)時監(jiān)控告警系統(tǒng)
HertzBeat是一款開源的實(shí)時監(jiān)控告警系統(tǒng),本文就來介紹一下Docker部署HertzBeat實(shí)時監(jiān)控告警系統(tǒng),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-11-11
docker?compose部署mongodb?分片集群的操作方法
分片機(jī)制(Sharding)是MongoDB中用于處理大規(guī)模數(shù)據(jù)集和高負(fù)載應(yīng)用的一種數(shù)據(jù)分布策略,通過將數(shù)據(jù)均勻分布在多個服務(wù)器上,分片技術(shù)能夠提高應(yīng)用的可擴(kuò)展性和性能,本文給大家介紹docker?compose部署mongodb?分片集群的相關(guān)操作,感興趣的朋友一起看看吧2024-10-10
使用Docker Compose創(chuàng)建LAMP環(huán)境的詳細(xì)步驟
現(xiàn)如今,通過 Docker 容器化部署環(huán)境已經(jīng)逐漸成為主流,特別是在部署像 LAMP 這樣的復(fù)雜環(huán)境時,本教程旨在帶您完成使用 Docker-Compose 建立 LAMP 環(huán)境的整個過程,同時還包括定制 PHP 環(huán)境的步驟,需要的朋友可以參考下2024-12-12
docker網(wǎng)絡(luò)端口映射的實(shí)現(xiàn)步驟
本文主要介紹了docker網(wǎng)絡(luò)端口映射的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07

