青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長網(wǎng)

17站長網(wǎng) 首頁 網(wǎng)站 服務器 查看內容

基于Docker如何實現(xiàn)MySQL主從復制詳解

2022-10-14 13:26| 查看: 1266 |來源: 互聯(lián)網(wǎng)

MySQL的主從復制是實現(xiàn)應用的高性能,高可用的基礎。對于數(shù)據(jù)庫讀操作較密集的應用,通過使數(shù)據(jù)庫請求負載均衡分配到不同MySQL服務器,可有效減輕數(shù)據(jù)庫壓力。當 ...

前言

MySQL的主從復制是實現(xiàn)應用的高性能,高可用的基礎。對于數(shù)據(jù)庫讀操作較密集的應用,通過使數(shù)據(jù)庫請求負載均衡分配到不同MySQL服務器,可有效減輕數(shù)據(jù)庫壓力。當遇到MySQL單點故障中,也能在短時間內實現(xiàn)故障切換。本文就MySQL的內建的復制功能進行闡述。

版本

  • MySQl: 5.7.17

  • CentOS: 7.4.1708

  • Docker: 1.13.1

概述

MySQL復制數(shù)據(jù)流程:

  1. 主庫在數(shù)據(jù)更新提交事務之前,將事件異步記錄到binlog二進制日志文件中,日志記錄完成后存儲引擎提交本次事務

  2. 從庫啟動一個I/O線程與主庫建立連接,用來請求主庫中要更新的binlog。這時主庫創(chuàng)建的binlog dump線程,這是二進制轉儲線程,如果有新更新的事件,就通知I/O線程;當該線程轉儲二進制日志完成,沒有新的日志時,該線程進入sleep狀態(tài)。

  3. 從庫的I/O線程接收到新的事件日志后,保存到自己的relay log(中繼日志)中

  4. 從庫的SQL線程讀取中繼日志中的事件,并執(zhí)行更新保存。

配置主從庫

主庫my.cnf配置

在主庫的my.cnf中打開二進制日志,并設置服務Id。

log-bin = mysql-bin
server-id = 1

注意server-id必須是一個唯一的數(shù)字,必須主從不一致, 且主從庫必須設置項。

從庫my.cnf配置

log-bin = mysql-bin
server-id = 2
log-slave-updates = 1
read-only = 1

從庫也開啟log-bin,log-slave-updates設置為從庫重放中繼日志時,記錄到自己的二進制日志中,可以讓從庫作為其他服務器的主庫,將二進制日志轉發(fā)給其他從庫,在做一主多從方案時可考慮該種方案。

Dockerfile構建MySQL鏡像

構建所需文件

這里master和slave文件各自保存不共用,先創(chuàng)建文件夾 /usr/local/mysql 然后在目錄創(chuàng)建master和slave兩個目錄,再各自創(chuàng)建data文件夾

  • data 目錄用來保存數(shù)據(jù)文件的目錄

  • Dockerfile 保存Dockerfile內容

  • init.sql 初始化數(shù)據(jù)庫的SQL

  • my.cnf 數(shù)據(jù)庫配置文件,配置方式上面已提到

  • start.sh Dockerfile構建MySQL時的腳本

Dockerfile 內容

# 利用 mysql 鏡像創(chuàng)建新的鏡像
FROM mysql:5.7.17

ENV MYSQL_ROOT_PASSWORD ytao

COPY start.sh /mysql/start.sh
COPY my.cnf /etc/mysql/my.cnf 
COPY init.sql /mysql/init.sql

EXPOSE 3306
CMD ["sh", "/mysql/start.sh"]

這里的master和slave都是基于同一個鏡像構建,使用的存儲引擎和其他的組件最好是同一中,不然在復制過程中可能會出現(xiàn)異常。

init.sql 初始化數(shù)據(jù)

-- 創(chuàng)建 data_copy 數(shù)據(jù)庫
DROP DATABASE IF EXISTS `data_copy`;
CREATE DATABASE `data_copy` /*!40100 DEFAULT CHARACTER SET utf8mb4 collate utf8mb4_general_ci */;

-- 創(chuàng)建 person 表
USE `data_copy`;
DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
 `id` int(32) NOT NULL,
 `name` varchar(255) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

創(chuàng)建data_copy數(shù)據(jù)庫和person表。

start.sh 腳本

#!/bin/sh
echo '啟動mysql'
service mysql start
sleep 5

echo '初始化數(shù)據(jù)庫'
mysql -uroot -pytao < /mysql/init.sql
echo '初始化完成!'
tail -f /dev/null

構建master和slave鏡像并運行容器

構建master鏡像

docker build -t master/mysql .

構建slave鏡像

docker build -t slave/mysql .

構建成功會返回 Successfuly,或通過docker images命令查看鏡像

使用剛構建的鏡像來運行容器

# master 容器
docker run --name master -p 3306:3306 -v /usr/local/mysql/master/data/:/var/lib/mysql -d master/mysql

# slave 容器
docker run --name slave -p 3307:3306 -v /usr/local/mysql/slave/data/:/var/lib/mysql -d slave/mysql

指定master端口為3306,slave端口為3307,掛載data目錄為保存數(shù)據(jù)的目錄。

連接到數(shù)據(jù)庫后驗證數(shù)據(jù)庫是否初始化成功

查看 log-bin 是否開啟

創(chuàng)建復制賬號

前面有提到從庫I/O線程要與主庫建立連接,所以需要用到賬號進行驗證。賬號除了要有連接權限(REPLICATION CLIENT),同時還要有復制權限(REPLICATION SLAVE)。

GRANT REPLICATION CLIENT, REPLICATION SLAVE ON *.* TO muser@'%' IDENTIFIED BY 'ytao';

這里設置的訪問地址是開放的,實際使用過程中安全起見一定要指定訪問地址。

從庫啟動復制

從庫連接到主庫,獲取到二進制日志后重放。這里首先要配置上面創(chuàng)建的賬號進行連接,使用命令進行相應的設置。

CHANGE MASTER TO 
MASTER_HOST = '47.107.xx.xxx',
MASTER_PORT = 3306,
MASTER_USER = 'muser',
MASTER_PASSWORD = 'ytao',
MASTER_LOG_FILE = 'mysql-bin.000006';

到這里復制還沒有啟動,需要再從庫中啟動

START SLAVE;

使用SHOW SLAVE STATUS\G;命令查看啟動后的情況

上面標記的輸出信息Slave_IO_Running: Yes和Slave_SQL_Running: Yes可以看到I/O線程和SQL線程已啟動運行中。

測試同步數(shù)據(jù)

如果在主庫中添加,更新或刪除一個數(shù)據(jù),那么從庫中應該也有與主庫對應的數(shù)據(jù)變化。

向主庫添加一條數(shù)據(jù)

INSERT INTO `data_copy`.`person` (`id`, `name`) VALUES ('1', 'ytao');

查詢從庫數(shù)據(jù),數(shù)據(jù)已被同步過來。

總結

上述是最簡單最基本的配置,但是理解上面的配置過程,就可以根據(jù)自身情況定制不同方案,實現(xiàn)一主多從,主主復制(主動-主動或主動-被動模式)等等來滿足自身需求。

MySQL的復制雖然使用簡單方便,但也伴隨著一些問題需要我們在使用中進行解決,比如:不能從服務器異常停止中恢復,數(shù)據(jù)同步的延遲等等,還好現(xiàn)在遇到的大部分問題在行業(yè)中已得到相應的解決。對這方面感興趣的可以去了解下現(xiàn)在解決這些問題的中間件實現(xiàn)方案。

以上就是小編給大家介紹的基于Docker如何實現(xiàn)MySQL主從復制詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

本文最后更新于 2022-10-14 13:26,某些文章具有時效性,若有錯誤或已失效,請在網(wǎng)站留言或聯(lián)系站長:17tui@17tui.com
·END·
站長網(wǎng)微信號:w17tui,關注站長、創(chuàng)業(yè)、關注互聯(lián)網(wǎng)人 - 互聯(lián)網(wǎng)創(chuàng)業(yè)者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業(yè)用途,如果損害了您的權利,請聯(lián)系我們及時修正或刪除。謝謝!

17站長網(wǎng)微信二維碼

始終以前瞻性的眼光聚焦站長、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長轉型升級,為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質的創(chuàng)業(yè)信息和品牌營銷服務,與站長一起進步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨!

掃一掃,關注站長網(wǎng)微信

大家都在看

熱門排行

    最近更新

      返回頂部
      主站蜘蛛池模板: 黄色三级三级免费看 | 国产亚洲精品久久精品6 | 男人J桶女人P视频无遮挡网站 | 国产免费人视频在线观看免费 | 亚洲三级在线观看 | vr亚洲成年网址在线观看 | 美国兽皇zoo在线播放 | 一本道亚洲区免费观看 | 啊灬啊灬啊灬快高潮视频 | 在线a亚洲视频 | 日韩精品卡1卡2三卡四卡乱码 | 精品国产成人a区在线观看 精品国产成人AV在线看 | 高清视频在线观看SEYEYE | 亚洲中字幕永久在线观看 | 在线 自拍 综合 亚洲 欧美 | 亚洲男人片片在线观看 | yellow片高清视频免费看 | 粉嫩AV国产一区二区福利姬 | 看免费人成va视频全 | gayxxxxgay呻吟受日本 | 大桥未久与黑人中出视频 | 亚洲伊人情人综合网站 | 久久精品电影久久电影大全 | 晓雪老师我要进你里面好爽 | 三级网址在线 | qvod在线观看| 黑兽在线观看高清在线播放樱花 | 亚洲乱亚洲乱妇13p 亚洲乱色视频在线观看 | 拉菲娱乐主管高工资q39709 | 色狠狠AV老熟女 | 轻点慢点1V2啊高H抽插 | 男的插曲女的下面免费APP | 久久国产主播福利在线 | 久久久久综合一本久道 | 精品午夜国产福利观看 | 永久午夜福利视频一区在线观看 | 无限资源在线观看完整版免费下载 | 国产免费人成在线视频视频 | 国产成人精选免费视频 | 中文字幕在线观看网站 | 玖玖爱这里只有精品视频 |