docker實現(xiàn)MySQL主從雙備的示例代碼
環(huán)境配置
本地操作系統(tǒng):Win10
虛擬機的操作系統(tǒng):CentOS Stream 8
已安裝docker,可以參考詳細(xì)安裝教程
MySQL基礎(chǔ)知識
搭建MySQL主從雙備是在docker情況下自定義MySQL的配置文件,在上一節(jié)我們講述了如何掛載docker的MySQL數(shù)據(jù)文件,其中run指令參數(shù)-v /home/mysql/conf:/etc/mysql/conf.d是掛載MySQL的配置文件。
當(dāng)我們通過指令進(jìn)入docker內(nèi)部查看MySQL配置文件的時候,發(fā)現(xiàn)/etc/mysql/conf.d只是一個文件夾,同目錄情況下分別有配置文件my.cnf和my.cnf.fallback,如圖所示
在MySQL中,/etc/mysql/my.cnf 是默認(rèn)配置文件,/etc/conf.d/ 下的文件為自定義配置文件,比如 /etc/mysql/conf.d/my.cnf 文件。
由于docker的/etc/mysql/conf.d文件掛載到本地系統(tǒng)的/home/mysql/conf,因此我們只需在本地系統(tǒng)的/home/mysql/conf寫入配置文件即可修改docker的MySQL配置。
搭建主MySQL
由于docker的mysql默認(rèn)使用/etc/mysql/my.cnf的配置文件,如果要自定義配置文件,需要進(jìn)入docker的MySQL獲取默認(rèn)配置文件/etc/mysql/my.cnf的配置信息,然后在本地系統(tǒng)的/home/mysql/conf編寫配置文件。
假設(shè)主MySQL的容器名稱為mysql10 ,docker啟動指令如下:
docker run --name mysql10 -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=1234 -d mysql
進(jìn)入docker獲取MySQL默認(rèn)配置信息方法如下:
# 進(jìn)入容器,mysql10 是容器名稱 docker exec -it mysql10 bash # 查看MySQL默認(rèn)配置文件 cat /etc/mysql/my.cnf
上述指令執(zhí)行結(jié)果如圖所示
將上圖的配置信息寫入本地系統(tǒng)的自定義配置文件/home/mysql/conf/mysql.cnf,并添加屬性log-bin和server-id
[mysqld] pid-file=/var/run/mysqld/mysqld.pid socket=/var/run/mysqld/mysqld.sock datadir=/var/lib/mysql secure-file-priv= NULL # 開啟二進(jìn)制日志,屬性值mysql-bin 是日志的基本名或前綴名 log-bin=mysql-bin # server-id可隨便設(shè)置,但必須保證是唯一,數(shù)值為1到2的32次方–1之間的一個正整數(shù) server-id=2
配置文件完成后,使用指令docker restart mysql10重啟docker
搭建從MySQL
假設(shè)主MySQL的容器名稱為mysql11,docker啟動指令如下:
docker run --name mysql11 -p 3307:3306 -v /home/mysql11/conf:/etc/mysql/conf.d -v /home/mysql11/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=1234 -d mysql
在本地系統(tǒng)的/home/mysql11/conf編寫自定義配置文件mysql.cnf,如下所示:
[mysqld] pid-file=/var/run/mysqld/mysqld.pid socket=/var/run/mysqld/mysqld.sock datadir=/var/lib/mysql secure-file-priv= NULL # 開啟二進(jìn)制日志,屬性值mysql-bin 是日志的基本名或前綴名 log-bin=mysql-bin # server-id可隨便設(shè)置,但必須保證是唯一,數(shù)值為1到2的32次方–1之間的一個正整數(shù) server-id=3
配置文件完成后,使用指令docker restart mysql11重啟docker
配置主從復(fù)制
現(xiàn)在我們已搭建兩個docker容器,每個容器分別運行端口3306和3307的MySQL,并且對每個MySQL設(shè)置了自定義配置文件。下一步在從MySQL設(shè)置主MySQL的監(jiān)聽功能,我們使用Navicat Premium 15連接從MySQL,然后執(zhí)行下面SQL語句,這樣就能實現(xiàn)主從復(fù)制,代碼如下:
-- 監(jiān)聽主MySQL CHANGE MASTER TO -- 主MySQL的IP、端口、用戶名和密碼 MASTER_HOST = '192.168.3.250', MASTER_PORT = 3306, MASTER_USER = 'root', MASTER_PASSWORD = '1234'; -- 開啟監(jiān)聽功能 START SLAVE; -- 查詢監(jiān)聽狀態(tài) SHOW SLAVE STATUS;
執(zhí)行上述SQL語句之后,在查詢結(jié)果找到Slave_IO_Running和Slave_SQL_Running,如果兩個字段的值皆為Yes則說明配置成功,如圖所示:
如果配置失敗,則可以通過docker指令查看日志記錄,指令如下:
# mysql11是從MySQL的容器名稱 docker logs mysql11 -f
大部分配置失敗都是主MySQL的IP、端口、用戶名和密碼錯誤導(dǎo)致的,具體信息還得分析docker的日志記錄。
拓展
至此,我們已完成2臺MySQL服務(wù)的主從雙備功能(從復(fù)制主),功能測試可以在Navicat Premium 15自行測試。
此外還可以實現(xiàn)主從互備(從復(fù)制主,主復(fù)制從)、搭建多臺MySQL的主從關(guān)系等功能,這些功能主要在配置文件my.cnf添加相應(yīng)配置屬性和執(zhí)行對應(yīng)SQL語句。
到此這篇關(guān)于docker實現(xiàn)MySQL主從雙備的文章就介紹到這了,更多相關(guān)docker實現(xiàn)MySQL主從雙備內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker配置MySql環(huán)境的實現(xiàn)步驟
通過使用Docker,開發(fā)人員可以更容易地構(gòu)建、測試和交付應(yīng)用程序,同時減少了環(huán)境配置和依賴項管理的復(fù)雜性,本文主要介紹了Docker配置MySql環(huán)境的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),感興趣的可以了解一下2024-02-02windows server 2016安裝docker的方法步驟
這篇文章主要介紹了windows server 2016安裝docker的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06Docker部署Kafka以及Spring Kafka實現(xiàn)
這篇文章主要介紹了Docker部署Kafka以及Spring Kafka實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10docker-compose部署coredns如何實現(xiàn)自建DNS服務(wù)
本文介紹了如何在內(nèi)網(wǎng)中使用自建的CoreDNS服務(wù)進(jìn)行域名解析,通過配置Corefile和hosts文件,實現(xiàn)內(nèi)部域名解析,無需在互聯(lián)網(wǎng)上注冊域名,使用docker-compose運行CoreDNS,并通過修改resolv.conf文件配置DNS服務(wù)2025-01-01