电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

詳細分析MySQL主從復制

瀏覽:2日期:2023-10-12 19:49:18

前言:

在MySQL中,主從架構應該是最基礎、最常用的一種架構了。后續的讀寫分離、多活高可用架構等大多都依賴于主從復制。主從復制也是我們學習MySQL過程中必不可少的一部分,關于主從復制的文章有很多,筆者也來湊湊熱鬧,寫寫這方面的內容吧,同時分享下自己的經驗和方法。

1.主從復制簡介及原理

主從復制(也稱 AB 復制)是指一臺服務器充當主數據庫服務器,另一臺或多臺服務器充當從數據庫服務器,主服務器中的數據自動復制到從服務器之中。對于多級復制,數據庫服務器既可充當主機,也可充當從機。MySQL默認采用異步復制方式。

主從復制的過程及原理可以總結如下:

master服務器將數據的改變記錄二進制binlog日志,當master上的數據發生改變時,則將其改變寫入二進制日志中。 slave服務器會在一定時間間隔內對master二進制日志進行探測其是否發生改變,如果發生改變,則開始一個I/OThread請求master二進制事件。 同時主節點為每個I/O線程啟動一個dump線程,用于向其發送二進制事件,并保存至從節點本地的中繼日志中,從節點將啟動SQL線程從中繼日志中讀取二進制日志,在本地重放,使得其數據和主節點的保持一致。

詳細分析MySQL主從復制

2.基于二進制文件位置配置主從復制

基于二進制文件位置的主從復制又可以稱為傳統復制,即從服務器依賴于主服務器的binlog文件位置,當主庫發生數據變更時,binlog pos位點會增長,從庫會感應到變化來完成同步。

配置主從復制,我們首先要準備至少兩臺MySQL實例,一臺充當主服務器、一臺充當從服務器。由于主從復制依賴于binlog,所以主庫必須開啟binlog,且主從要配置不同的server_id,下面具體展示下配置過程:

2.1 確認主從庫配置參數

MySQL主從服務器建議有如下配置,可以先確認下,如果未配置,則需要修改配置文件然后重啟。

# 主庫參數配置 要有以下參數vim /etc/my.cnf [mysqld] log-bin = binlog //啟用二進制日志server-id = 137 //服務器唯一ID,默認值是1,一般設置為IP地址的最后一段數字binlog_format = row //bilog設置為row模式 防止復制出錯# 從庫建議配置以下參數vim /etc/my.cnf [mysqld] relay-log = relay-binserver-id = 138

2.2 確定主庫二進制位置,創建同步賬號

若主從庫都是剛剛初始化完成,且主庫無操作時,從庫可不用同步主庫的數據,直接確定主庫的binlog位置即可。

# 查看主庫binlog文件位置show master status;# 主庫創建同步賬號create user ’repl’@’%’ identified by ’123456’;grant replication slave on *.* to ’repl’@’%’;

若主庫已經運行了一段時間,有業務數據在,而從庫剛剛初始化完成,此時則需要備份主庫的數據,然后導入從庫,使得主從數據一致。

# 主庫創建同步賬號create user ’repl’@’%’ identified by ’123456’;grant replication slave on *.* to ’repl’@’%’;# 全備主庫數據mysqldump -uroot -pxxxx -A -R -E --single-transaction --master-data=2 > all_db.sql# 從庫端恢復mysql -uroot -pxxxx < all_db.sql# 從備份文件中可以找到主庫的binlog位置

2.3 進入從庫,開啟主從復制

找到主庫二進制文件位置且完成主從數據一致后,我們就可以正式開啟主從復制了。

# 進入從庫MySQL命令行 執行change master語句連接主庫# 二進制文件名及pos位置由上面步驟獲得CHANGE MASTER TO MASTER_HOST=’MySQL主服務器IP地址’, MASTER_PORT=3306, MASTER_USER=’repl’, MASTER_PASSWORD=’123456’, MASTER_LOG_FILE=’binlog.000002’, MASTER_LOG_POS=154; # 開啟主從復制 并堅持狀態start slave;show slave status G //查看slave狀態 確保Slave_IO_Running: Yes Slave_SQL_Running: Yes

3.基于GTID的主從復制

GTID是MySQL 5.6的新特性,其全稱是Global Transaction Identifier,可簡化MySQL的主從切換以及Failover。GTID用于在binlog中唯一標識一個事務。當事務提交時,MySQL Server在寫binlog的時候,會先寫一個特殊的Binlog Event,類型為GTID_Event,指定下一個事務的GTID,然后再寫事務的Binlog。

在基于GTID的復制中,首先從服務器會告訴主服務器已經在從服務器執行完了哪些事務的GTID值,然后主庫會有把所有沒有在從庫上執行的事務,發送到從庫上進行執行,并且使用GTID的復制可以保證同一個事務只在指定的從庫上執行一次,這樣可以避免由于偏移量的問題造成數據不一致。也就是說,無論是級聯情況,還是一主多從的情況,都可以通過GTID自動找位置,而無需像之前那樣通過File_name和File_position找主庫binlog位置了。

基于GTID的主從復制與上面基于二進制文件位置的主從復制搭建步驟類似,同樣簡單展示下搭建過程:

3.1 確認主從庫配置,開啟GTID

# 主庫參數配置 要有以下參數vim /etc/my.cnf [mysqld] server-id = 137log-bin = binlog binlog_format = row gtid-mode = ON //開啟gtid模式enforce-gtid-consistency = ON //強制gtid一致性,用于保證啟動gitd后事務的安全 # 從庫建議配置以下參數vim /etc/my.cnf [mysqld] server-id = 138log-bin = binlog binlog_format = row gtid-mode = ON enforce-gtid-consistency = ON relay-log = relay-bin

3.2 創建同步賬號,保持主從庫數據一致

若主庫剛初始化完成或者主庫端保留有全部二進制文件,則從庫無需手動同步數據。否則需要手動同步數據使得主從一致。

# 主庫創建同步賬號create user ’repl’@’%’ identified by ’123456’;grant replication slave on *.* to ’repl’@’%’;# 若主庫剛初始化或保留有完整二進制文件 則無需執行下面步驟# 全備主庫數據mysqldump -uroot -pxxxx -A -R -E --single-transaction > all_db.sql# 從庫端恢復mysql -uroot -pxxxx < all_db.sql

3.3 進入從庫,開啟主從復制

# 進入從庫MySQL命令行 執行change master語句連接主庫CHANGE MASTER TO MASTER_HOST=’MySQL主服務器IP地址’, MASTER_PORT=3306, MASTER_USER=’repl’, MASTER_PASSWORD=’123456’, MASTER_AUTO_POSITION = 1; # 開啟主從復制 并堅持狀態start slave;show slave status G

4.一些經驗及建議

在日常學習及工作過程中,主從復制方面也積累了一些經驗,下面簡單分享幾點,希望各位少踩坑。

主從兩端數據庫版本盡量保持一致。 主從庫參數建議相同,比如字符集、sql_mode這類參數要設置一樣。 從庫服務器性能不能過于落后主庫,以免因服務器性能產生主從延遲。 所有表強制擁有主鍵,因為無主鍵表同步到從庫極易產生主從延遲。 建議從庫設為read only,以防人為誤操作從庫數據。 監控主從延遲及狀態,及時解決同步中斷或延遲問題。

總結:

本文介紹了主從復制的原理及搭建過程,其實關于主從復制的內容還有很多,需要不斷的學習。這里推薦大家使用GTID模式來搭建主從復制,關于后面分享的幾點經驗,也是自己日常積累的,希望對你有所幫助。寫作不易,覺得還不錯的話,請順手轉發分享下哦。

以上就是詳細分析MySQL主從復制的詳細內容,更多關于MySQL主從復制的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: elisa试剂盒-PCR试剂盒「上海谷研实业有限公司」 | lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 螺旋叶片_螺旋叶片成型机_绞龙叶片_莱州源泽机械制造有限公司 | 圆周直径尺-小孔内视镜-纤维研磨刷-东莞市高腾达精密工具 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 小程序开发公司_APP开发多少钱_软件开发定制_微信小程序制作_客户销售管理软件-济南小溪畅流网络科技有限公司 | 长沙网站建设制作「网站优化推广」-网页设计公司-速马科技官网 | 加气混凝土砌块设备,轻质砖设备,蒸养砖设备,新型墙体设备-河南省杜甫机械制造有限公司 | 昆明化妆培训-纹绣美甲-美容美牙培训-昆明博澜培训学校 | 双舌接地线-PC68数字式高阻计-ZC36|苏海百科| LNG鹤管_内浮盘价格,上装鹤管,装车撬厂家-连云港赛威特机械 | 山东石英砂过滤器,除氟过滤器「价格低」-淄博胜达水处理 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | RV减速机-蜗轮蜗杆减速机-洗车机减速机-减速机厂家-艾思捷 | 硅PU球场、篮球场地面施工「水性、环保、弹性」硅PU材料生产厂家-广东中星体育公司 | 东莞猎头公司_深圳猎头公司_广州猎头公司-广东万诚猎头提供企业中高端人才招聘服务 | 三效蒸发器_多效蒸发器价格_四效三效蒸发器厂家-青岛康景辉 | 中图网(原中国图书网):网上书店,尾货特色书店,30万种特价书低至2折! | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 耐磨陶瓷,耐磨陶瓷管道_厂家-淄博拓创陶瓷科技 | 厦门网站建设_厦门网站设计_小程序开发_网站制作公司【麦格科技】 | 微信聊天记录恢复_手机短信删除怎么恢复_通讯录恢复软件下载-快易数据恢复 | sus630/303cu不锈钢棒,440C/430F/17-4ph不锈钢研磨棒-江苏德镍金属科技有限公司 | 芜湖厨房设备_芜湖商用厨具_芜湖厨具设备-芜湖鑫环厨具有限公司 控显科技 - 工控一体机、工业显示器、工业平板电脑源头厂家 | lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 起好名字_取个好名字_好名网免费取好名在线打分 | 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 车间除尘设备,VOCs废气处理,工业涂装流水线,伸缩式喷漆房,自动喷砂房,沸石转轮浓缩吸附,机器人喷粉线-山东创杰智慧 | 二次元影像仪|二次元测量仪|拉力机|全自动影像测量仪厂家_苏州牧象仪器 | 螺旋压榨机-刮泥机-潜水搅拌机-电动泥斗-潜水推流器-南京格林兰环保设备有限公司 | 工业插头-工业插头插座【厂家】-温州罗曼电气 | 医用酒精_84消毒液_碘伏消毒液等医用消毒液-漓峰消毒官网 | 天津次氯酸钠酸钙溶液-天津氢氧化钠厂家-天津市辅仁化工有限公司 | 武汉森源蓝天环境科技工程有限公司-为环境污染治理提供协同解决方案 | 起好名字_取个好名字_好名网免费取好名在线打分 | 合肥仿石砖_合肥pc砖厂家_合肥PC仿石砖_安徽旭坤建材有限公司 | 高通量组织研磨仪-多样品组织研磨仪-全自动组织研磨仪-研磨者科技(广州)有限公司 | 阿米巴企业经营-阿米巴咨询管理-阿米巴企业培训-广东键锋企业管理咨询有限公司 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 运动木地板_体育木地板_篮球馆木地板_舞台木地板-实木运动地板厂家 |