docker搭建mysql主從同步的全過程
引言
以前在centos上裝一個mysql redis 能搞兩三天,各種編譯問題,自從用了docker做開發(fā)環(huán)境之后是真的香,真正體會了一把什么叫一鍵啟動。
最近開發(fā)環(huán)境自己搭個主從的結構使用,mark一下,順便分享一下中間可能遇到的問題
搭建流程
docker容器準備
這里以mysql 8.0為例
# 拉取鏡像,自己配一下docker鏡像源,幾十秒就下完了 docker pull mysql:8.0 # 創(chuàng)建容器之間的通信網絡 docker network create mysql_db ### 啟動主庫 docker run -p 3340:3306 --name mysql-m --network mysql_db -e MYSQL_ROOT_PASSWORD=主庫root密碼 -d mysql:8.0 ### 啟動從庫 docker run -p 3341:3306 --name mysql-s --network mysql_db -e MYSQL_ROOT_PASSWORD=從庫root密碼 -d mysql:8.0
接下來就是進入容器開始配置mysql主從信息了
這里記得提前創(chuàng)建一個用來同步的用戶,記得賦權
CREATE USER `slave`@`%` IDENTIFIED WITH mysql_native_password BY '123456'; # 授權 GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' identified by '123456'; # 檢查一下 show grants for 'slave'@'%'; # 沒有的話刷新一下 flush PRIVILEGES;
# 修改主庫配置 docker exec -it mysql-m /bin/bash # 這里需要安裝一下vim apt-get update apt-get install vim vim /etc/mysql/my.cnf #1.配置server-id 保證同一網絡中不重復,其實就普通的主從配置一樣了 #2.開啟logbin 主從同步其實就是讀取binlog的過程 [mysqld] server-id=101 log-bin=mysql-bin # 修改從庫配置 docker exec -it mysql-s /bin/bash vim /etc/mysql/my.cnf # 配置server-id log-bin和relay-log # mysql會將變化寫入relaylog 從庫來讀取relaylog做同步 [mysqld] server-id=102 log-bin=mysql-slave-bin relay-log=mysql-relay-bin
執(zhí)行同步
重啟主從服務,進入主庫查看主庫狀態(tài) show master status;
記錄binlog文件和position ,比如 mysql-bin.000002 1894;
進入從庫,執(zhí)行以下命令
CHANGE MASTER TO master_host = '172.17.0.2', master_user = 'slave', master_password = '123456', master_port = 3306, master_log_file = 'mysql-bin.000002', master_log_pos = 1894, master_connect_retry = 30;
查看從庫狀態(tài) SHOW SLAVE STATUS;
這里應該可以看到配置的主庫host和端口,日志文件及位置信息,但是此時IO是關閉的,還沒有線程開始對主庫binlog進行同步和對relaylog進行讀取。
這里要提一下,上面docker啟動容器時我們把端口映射到了3340 和3341 ,但是對于docker容器內部訪問時,端口還是3306,主庫ip地址可以執(zhí)行 docker inspect mysql-m
查看自己配置的網絡組或者bridge 的IPAddress
然后就是在從庫開啟slave了,start slave;
關閉同步 stop slave;
接下來就可以愉快地測試啦
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
一文搞清楚MySQL count(*)、count(1)、count(col)區(qū)別
本文主要介紹了MySQL count(*)、count(1)、count(col)區(qū)別,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03解決Navicat for MySQL 連接 MySQL 報2005錯誤的問題
在本地MySQL的服務啟動后,由于Navicat的一些功能需要聯網才可以使用,今天重點給大家介紹Navicat for MySQL 連接 MySQL 報2005 -Unknown MySQL server host ‘localhost’(0)錯誤的情況與解決方法,感興趣的朋友一起看看吧2021-05-05linux下改良版本mysqldump來備份MYSQL數據庫
我的備份腳本都是在凌晨執(zhí)行的,經常在慢查詢日志里面看到這樣的信息:select * from table1; 之前一直很納悶,最后才了解到原來是MYSQLDUMP搞的鬼。2008-07-07MySQL?count(*),count(id),count(1),count(字段)區(qū)別
本文主要介紹了MySQL?count(*),count(id),count(1),count(字段)區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-05-05