使用Docker搭建MySQL主從數(shù)據(jù)庫的方法步驟
很多人對主從數(shù)據(jù)庫有一個誤區(qū),把多個MySQL搭建在同一個服務器上,性能提升是不是很有限?這個理念是錯誤的,數(shù)據(jù)庫的性能瓶頸主要是在IO和CPU負載過高,在同一臺服務器運行多個數(shù)據(jù)庫,能帶來更低的延遲,還能減少很多其他問題,如果不是數(shù)據(jù)量大到了一定程度,在同一臺服務器上創(chuàng)建多個數(shù)據(jù)庫帶來的性能提示是非??捎^的。
服務器規(guī)劃:使用docker方式創(chuàng)建,主從服務器IP一致,端口號不一致,密碼都設置為123456
- 主服務器:容器名
mysql-master,端口3306 - 從服務器:容器名
mysql-slave1,端口3307 - 從服務器:容器名
mysql-slave2,端口3308
1. 準備主服務器
docker run -d \ -p 3306:3306 \ -v /xk857/mysql/master/conf:/etc/mysql/conf.d \ -v /xk857/mysql/master/data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ --name mysql-master \ mysql:8.0.29
默認情況下MySQL的binlog日志是自動開啟的,可以通過如下配置定義一些可選配置
vim /xk857/mysql/master/conf/my.cnf
配置如下內容,注意和新配置只有三行,其他配置可根據(jù)實際情況選用。
[mysqld] # 服務器唯一id,默認值1 server-id=1 # 設置日志格式,默認值ROW binlog_format=STATEMENT # 二進制日志名,默認binlog # log-bin=binlog # 設置需要復制的數(shù)據(jù)庫,默認復制全部數(shù)據(jù)庫 #binlog-do-db=mytestdb # 設置不需要復制的數(shù)據(jù)庫 #binlog-ignore-db=mysql #binlog-ignore-db=infomation_schema
重啟MySQL容器
docker restart mysql-master
binlog格式說明
- binlog_format=STATEMENT:日志記錄的是主機數(shù)據(jù)庫的寫指令,性能高,但是now()之類的函數(shù)以及獲取系統(tǒng)參數(shù)的操作會出現(xiàn)主從數(shù)據(jù)不同步的問題。
- binlog_format=ROW(默認):日志記錄的是主機數(shù)據(jù)庫的寫后的數(shù)據(jù),批量操作時性能較差,解決now()或者 user()或者 @@hostname 等操作在主從機器上不一致的問題。
- binlog_format=MIXED:是以上兩種level的混合使用,有函數(shù)用ROW,沒函數(shù)用STATEMENT,但是無法識別系統(tǒng)變量
使用命令行登錄MySQL主服務器:
#進入容器:env LANG=C.UTF-8 避免容器中顯示中文亂碼 docker exec -it mysql-master env LANG=C.UTF-8 /bin/bash #進入容器內的mysql命令行 mysql -uroot -p123456 #修改默認密碼校驗方式 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
主機中創(chuàng)建slave用戶:
-- 創(chuàng)建slave用戶 CREATE USER 'xk857_slave'@'%'; -- 設置密碼 ALTER USER 'xk857_slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; -- 授予復制權限 GRANT REPLICATION SLAVE ON *.* TO 'xk857_slave'@'%'; -- 刷新權限 FLUSH PRIVILEGES;
主機中查詢master狀態(tài),執(zhí)行完此步驟后不要再操作主服務器MYSQL,防止主服務器狀態(tài)值變化
SHOW MASTER STATUS;
2. 準備從服務器
可以配置多臺從機slave1、slave2…,這里以配置slave1和slave2為例,映射到主機的端口為3307
docker run -d \ -p 3307:3306 \ -v /xk857/mysql/slave1/conf:/etc/mysql/conf.d \ -v /xk857/mysql/slave1/data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ --name mysql-slave1 \ mysql:8.0.29 docker run -d \ -p 3308:3306 \ -v /xk857/mysql/slave2/conf:/etc/mysql/conf.d \ -v /xk857/mysql/slave2/data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ --name mysql-slave2 \ mysql:8.0.29
創(chuàng)建MySQL從服務器配置文件:
vim /xk857/mysql/slave1/conf/my.cnf vim /xk857/mysql/slave2/conf/my.cnf
配置如下內容:
[mysqld] # 服務器唯一id,每臺服務器的id必須不同,如果配置其他從機,注意修改id server-id=2 # 中繼日志名,默認xxxxxxxxxxxx-relay-bin #relay-log=relay-bin [mysqld] # 服務器唯一id,每臺服務器的id必須不同,如果配置其他從機,注意修改id server-id=3 # 中繼日志名,默認xxxxxxxxxxxx-relay-bin #relay-log=relay-bin
重啟MySQL容器
docker restart mysql-slave1 docker restart mysql-slave2
使用命令行登錄MySQL從服務器:
#進入容器: docker exec -it mysql-slave1 env LANG=C.UTF-8 /bin/bash #進入容器內的mysql命令行 mysql -uroot -p123456 #修改默認密碼校驗方式 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; #進入容器: docker exec -it mysql-slave2 env LANG=C.UTF-8 /bin/bash #進入容器內的mysql命令行 mysql -uroot -p123456 #修改默認密碼校驗方式 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
在從機上執(zhí)行以下SQL操作
CHANGE MASTER TO MASTER_HOST='192.168.31.115', MASTER_USER='xk857_slave',MASTER_PASSWORD='123456', MASTER_PORT=3306, MASTER_LOG_FILE='binlog.000003',MASTER_LOG_POS=1357;
3. 啟動主從同步
啟動從機的復制功能,執(zhí)行SQL:
START SLAVE; -- 查看狀態(tài)(不需要分號) SHOW SLAVE STATUS\G
**兩個關鍵進程:**下面兩個參數(shù)都是Yes,則說明主從配置成功!

4. 實現(xiàn)主從同步
在主機中執(zhí)行以下SQL,在從機中查看數(shù)據(jù)庫、表和數(shù)據(jù)是否已經(jīng)被同步
CREATE DATABASE db_user;
USE db_user;
CREATE TABLE t_user (
id BIGINT AUTO_INCREMENT,
uname VARCHAR(30),
PRIMARY KEY (id)
);
INSERT INTO t_user(uname) VALUES('zhang3');
INSERT INTO t_user(uname) VALUES(@@hostname);
5. 停止和重置
需要的時候,可以使用如下SQL語句
-- 在從機上執(zhí)行。功能說明:停止I/O 線程和SQL線程的操作。 stop slave; -- 在從機上執(zhí)行。功能說明:用于刪除SLAVE數(shù)據(jù)庫的relaylog日志文件,并重新啟用新的relaylog文件。 reset slave; -- 在主機上執(zhí)行。功能說明:刪除所有的binglog日志文件,并將日志索引文件清空,重新開始所有新的日志文件。 -- 用于第一次進行搭建主從庫時,進行主庫binlog初始化工作; reset master;
到此這篇關于使用Docker搭建MySQL主從數(shù)據(jù)庫的方法步驟的文章就介紹到這了,更多相關Docker搭建MySQL主從數(shù)據(jù)庫內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Linux環(huán)境下使用Docker搭建Jenkins容器的方法步驟
本文主要介紹了Linux環(huán)境下使用Docker搭建Jenkins容器的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-06-06
Docker容器內不能聯(lián)網(wǎng)的6種解決方案
今天小編就為大家分享一篇關于Docker容器內不能聯(lián)網(wǎng)的6種解決方案,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10
docker將本地鏡像發(fā)布到阿里云的實現(xiàn)方法
本文主要介紹了docker將本地鏡像發(fā)布到阿里云的實現(xiàn)方法,文中根據(jù)實例編碼詳細介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03

