docker mysql日志_面试官问:了解Mysql主从复制原理么?我呵呵一笑
生活随笔
收集整理的這篇文章主要介紹了
docker mysql日志_面试官问:了解Mysql主从复制原理么?我呵呵一笑
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
搭建Mysql主從同步之前,我們先來說他們之間同步的過程與原理:
同步復制過程
獻上一張圖,這張圖詮釋了整個同步過程
主從復制過程:
- slave節點與主節點進行連接,建立主從關系,并把從哪開始同步,及哪個日志文件都一并發送到master
- master將修改的數據保存到binlog中
- master開啟binlog dump線程,將binlog日志推送到連接的slave中
- slave接受到推送的binlog,slave開啟IO線程將數據寫到中繼日志(relay log)中
- slave同時還會開啟一個SQL線程,對比中繼日志中新增的內容,并且解析SQL,回放數據到從數據庫中
好的,復制過程已經說完了,我們現在實踐下,快速搭建一個mysql主從架構。
沒錯,我這里還是使用docker搭建,因為它很香啊!
搭建Mysql 主從
創建mysql網絡
docker network create mysqlNet安裝mysql
- 運行mysql主節點
- 修改配置文件
- 重啟mysql_master
- 在master節點上 創建給從節點進行復制的用戶
- 運行mysql從節點
- 編輯從節點配置文件
現在主從節點已經安裝完成,我們接下來需要讓他們建立關系:
先查看master節點當前的狀態,主要看下日志文件和當前的位置
docker exec -it mysql_master mysql -uroot -prootshow master status;exitexit結果如下:文件為mysql-bin.000001 位置為629
拿到這些信息之后,我們現在就可以讓從節點與主節點建立關系,并執行同步了:
docker exec -it mysql_slave mysql -uroot -prootchange master to master_host='mysql_master', master_user='mysql_slave', master_password='111111', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos= 629, master_connect_retry=30;我們繼續看下slave節點的狀態
show slave statusG;1我們看到我們在文首提到的兩個線程并沒有啟動,所以我們需要手動啟動著兩個線程,一個命令就好了
start slave;現在可以看到兩個線程已經在運行了。
到此,已經搭建完成了
測試
這個我就不演示了,大家可以在mysql_master上創建一個數據庫,看看是不是會同步到mysql_slave上。
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的docker mysql日志_面试官问:了解Mysql主从复制原理么?我呵呵一笑的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java汉字如何通过字节传输,求助,ja
- 下一篇: 捷波朗STORM耳机设置中文_2020年