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

您的位置:首頁技術(shù)文章
文章詳情頁

MySql主從復(fù)制機制全面解析

瀏覽:5日期:2023-10-04 09:19:42

作為一個關(guān)系型數(shù)據(jù)庫,MySQL內(nèi)建地提供數(shù)據(jù)復(fù)制機制,這使得在使用時,可以基于其復(fù)制機制實現(xiàn)高可用架構(gòu)等高級特性,從而使得MySQL無需借助額外的插件或其他工具就具備適用于生產(chǎn)環(huán)境。這是MySQL得到大面積實際應(yīng)用的條件之一。

基于MySQL的復(fù)制機制,不僅可以實現(xiàn)數(shù)據(jù)庫的高可用,還能實現(xiàn)如:性能擴展、異地災(zāi)備以及冷熱分離等高級特性。

高可用:通過配置一定的復(fù)制機制,MySQL實現(xiàn)了跨主機的數(shù)據(jù)復(fù)制,從而獲得一定的高可用能力,如果需要獲得更高的可用性,只需要配置多個副本,或者進行級聯(lián)復(fù)制就可以達到目的。 性能擴展:由于復(fù)制機制提供了多個數(shù)據(jù)備份,在讀寫一致性要求不高的場景下,可以通過配置一個或多個副本,將讀請求分發(fā)至副本節(jié)點,從而獲得整體上讀寫性能的提升。 異地災(zāi)備:只需要將副本節(jié)點部署到異地機房,就可以輕松獲得一定的異地災(zāi)備能力。實際當(dāng)中,需要考慮網(wǎng)絡(luò)延遲等可能影響整體表現(xiàn)的因素。 交易分離:通過配置復(fù)制機制,并將低頻、大運算量的交易發(fā)送至副本節(jié)點執(zhí)行,就可以避免這些交易與高頻交易競爭運算資源,從而避免整體的性能問題。

為了獲得上述能力,需要了解基本的MySQL復(fù)制機制,并結(jié)合實際應(yīng)用場景選擇恰當(dāng)?shù)呐渲谩?/p>主從復(fù)制機制

MySQL基于binlog實現(xiàn)主從復(fù)制,從節(jié)點跟蹤并獲取主節(jié)點binlog中最新更新并在自身進行重放,從而實現(xiàn)復(fù)制主節(jié)點數(shù)據(jù)。

下圖是MySQL主從復(fù)制過程的示意圖。在整個過程中涉及三個線程,他們的職責(zé)分別是:

主節(jié)點binlog dump線程:該線程在從節(jié)點連接上主節(jié)點后創(chuàng)建,負責(zé)向從節(jié)點發(fā)送binlog中新寫入的數(shù)據(jù)。在讀取binlog時,dump線程會首先獲取binlog的鎖,并在讀取完畢后立刻釋放,然后將讀取到的數(shù)據(jù)發(fā)送至從節(jié)點。 從節(jié)點I/O線程:從節(jié)點I/O線程職責(zé)為向主節(jié)點發(fā)送數(shù)據(jù)同步的請求,接收主節(jié)點發(fā)送的數(shù)據(jù)并將其寫入relay-log。 從節(jié)點SQL線程:該線程從relay-log中讀取數(shù)據(jù)更新并進行重放。

MySql主從復(fù)制機制全面解析

異步復(fù)制

默認情況下,MySQL的主從復(fù)制是異步復(fù)制,在這種機制下,主節(jié)點會在完成本地日志寫入后立刻響應(yīng)客戶端的請求,從節(jié)點的數(shù)據(jù)復(fù)制過程異步執(zhí)行。

很明顯,在這種機制下面,由于復(fù)制過程并不會影響主節(jié)點對客戶端請求的響應(yīng),因此,相比于單節(jié)點,并不會造成整體性能上的明顯損失。

但是,在這種機制下面,如果數(shù)據(jù)在主節(jié)點完成提交而未同步至從節(jié)點時主節(jié)點宕機,此時如果發(fā)生主從切換并寫入新的數(shù)據(jù),可能導(dǎo)致數(shù)據(jù)丟失或不一致。

半同步復(fù)制(semisynchronous replication)

從5.6版本開始,MySQL支持半同步復(fù)制,這種機制與異步復(fù)制相比主要有如下區(qū)別:

主節(jié)點在收到客戶端的請求后,必須在完成本節(jié)點日志寫入的同時,還需要等待至少一個從節(jié)點完成數(shù)據(jù)同步的響應(yīng)之后(或超時),才會響應(yīng)請求。

從節(jié)點只有在寫入relay-log并完成刷盤之后,才會向主節(jié)點響應(yīng)。

當(dāng)從節(jié)點響應(yīng)超時時,主節(jié)點會將同步機制退化為異步復(fù)制。在至少一個從節(jié)點恢復(fù),并完成數(shù)據(jù)追趕后,主節(jié)點會將同步機制恢復(fù)為半同步復(fù)制。

可以看出,相比于異步復(fù)制,半同步復(fù)制在一定程度上提高了數(shù)據(jù)的可用性,在未退化至異步復(fù)制時,如果主節(jié)點宕機,此時數(shù)據(jù)已復(fù)制至至少一臺從節(jié)點。

同時,由于向客戶端響應(yīng)時需要從節(jié)點完成響應(yīng),相比于異步復(fù)制,此時多出了主從節(jié)點上網(wǎng)絡(luò)交互的耗時以及從節(jié)點寫文件并刷盤的耗時,因此整體上集群對于客戶端的響應(yīng)性能表現(xiàn)必然有所降低。

主從復(fù)制格式

由于MySQL的復(fù)制機制是基于binlog的,因此binlog的格式就決定了主從復(fù)制的格式。binlog有基于行的和基于語句兩種,從而復(fù)制也有兩種對應(yīng)的格式。

Statement-Based Replication(SBR)

對于基于語句的復(fù)制機制,binlog僅記錄所執(zhí)行的語句。這種方式,有如下優(yōu)點:

自從3.23版本就存在,經(jīng)過長期驗證的成熟技術(shù) 寫入日志文件的數(shù)據(jù)更少,這意味著更少的文件寫入和網(wǎng)絡(luò)傳輸消耗,從而整體上可以更快的完成主從復(fù)制,提升性能表現(xiàn)。 日志文件記錄了所有數(shù)據(jù)庫上執(zhí)行的語句,可以用來進行審計等用途

有如下缺點:

用戶自定義函數(shù)(UDF)以及執(zhí)行結(jié)果不確定的函數(shù)無法進行復(fù)制 進行數(shù)據(jù)更新時,需要比基于行的復(fù)制更多的行鎖 對于如先插入后更新式的復(fù)雜語句,從節(jié)點需要進行完全的對應(yīng)重放,而基于行格式的復(fù)制只需要執(zhí)行最終結(jié)果即可 Row-Based Replication(RBR)

基于行的復(fù)制機制下,對應(yīng)binlog也是基于行的,這時每次數(shù)據(jù)更新當(dāng)寫入binlog時,都被轉(zhuǎn)化所有受影響行的變化。

這種復(fù)制方式,有如下優(yōu)點:

所有數(shù)據(jù)變化都可以被安全的復(fù)制,不會受到UDF以及特殊函數(shù)的影響。 大部分DBMS都采用這種復(fù)制方式,知識遷移成本低。 進行數(shù)據(jù)更新時,所需要的行鎖更少,從而可以獲取更高的性能表現(xiàn)。

有如下缺點:

在涉及大數(shù)據(jù)量的DML時,基于行的日志將會產(chǎn)生大量的日志數(shù)據(jù),大數(shù)據(jù)量在日志文件寫入、網(wǎng)絡(luò)傳輸方面都意味著更長的時間,從而可能導(dǎo)致整體性能表現(xiàn)顯著變差,同時也可能導(dǎo)致并發(fā)問題。 無法通過日志查看所執(zhí)行的語句,同時也無法獲知從節(jié)點上執(zhí)行的語句。

在實際的架構(gòu)應(yīng)用中,需要根據(jù)系統(tǒng)的業(yè)務(wù)特點合理利用主從復(fù)制機制,并選擇合適主從復(fù)制格式。

以上就是MySql主從復(fù)制機制全面解析的詳細內(nèi)容,更多關(guān)于MySql主從復(fù)制機制的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 智能楼宇-楼宇自控系统-楼宇智能化-楼宇自动化-三水智能化 | 成都办公室装修-办公室设计-写字楼装修设计-厂房装修-四川和信建筑装饰工程有限公司 | 沈阳网站建设_沈阳网站制作_沈阳网页设计-做网站就找示剑新零售 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 海南在线 海南一家 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 桥架-槽式电缆桥架-镀锌桥架-托盘式桥架 - 上海亮族电缆桥架制造有限公司 | 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 东莞市超赞电子科技有限公司 全系列直插/贴片铝电解电容,电解电容,电容器 | 磷酸肌酸二钠盐,肌酐磷酰氯-沾化欣瑞康生物科技 | 烟台条码打印机_烟台条码扫描器_烟台碳带_烟台数据采集终端_烟台斑马打印机-金鹏电子-金鹏电子 | 视觉检测设备_自动化检测设备_CCD视觉检测机_外观缺陷检测-瑞智光电 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 实验室隔膜泵-无油防腐蚀隔膜泵-耐腐蚀隔膜真空泵-杭州景程仪器 电杆荷载挠度测试仪-电杆荷载位移-管桩测试仪-北京绿野创能机电设备有限公司 | 罗氏牛血清白蛋白,罗氏己糖激酶-上海嵘崴达实业有限公司 | 苗木价格-苗木批发-沭阳苗木基地-沭阳花木-长之鸿园林苗木场 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 土壤有机碳消解器-石油|表层油类分析采水器-青岛溯源环保设备有限公司 | 冷柜风机-冰柜电机-罩极电机-外转子风机-EC直流电机厂家-杭州金久电器有限公司 | 代理记账_免费注册公司_营业执照代办_资质代办-【乐财汇】 | 超声波清洗机_细胞破碎仪_实验室超声仪器_恒温水浴-广东洁盟深那仪器 | 广东泵阀展|阀门展-广东国际泵管阀展览会 | 工业废水处理|污水处理厂|废水治理设备工程技术公司-苏州瑞美迪 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 高通量组织研磨仪-多样品组织研磨仪-全自动组织研磨仪-研磨者科技(广州)有限公司 | 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 膏方加工_丸剂贴牌_膏滋代加工_湖北康瑞生物科技有限公司 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | 深圳货架厂家_金丽声精品货架_广东金丽声展示设备有限公司官网 | 破碎机锤头_耐磨锤头_合金锤头-鼎成机械一站式耐磨铸件定制服务 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 企业VI设计_LOGO设计公司_品牌商标设计_【北京美研】 | 塑料检查井_双扣聚氯乙烯增强管_双壁波纹管-河南中盈塑料制品有限公司 | 螺旋压榨机-刮泥机-潜水搅拌机-电动泥斗-潜水推流器-南京格林兰环保设备有限公司 | 赛默飞Thermo veritiproPCR仪|ProFlex3 x 32PCR系统|Countess3细胞计数仪|371|3111二氧化碳培养箱|Mirco17R|Mirco21R离心机|仟诺生物 | 武汉森源蓝天环境科技工程有限公司-为环境污染治理提供协同解决方案 | 安规_综合测试仪,电器安全性能综合测试仪,低压母线槽安规综合测试仪-青岛合众电子有限公司 | 自动气象站_气象站监测设备_全自动气象站设备_雨量监测站-山东风途物联网 | 湖南专升本-湖南省专升本报名-湖南统招专升本考试网 | 郑州墨香品牌设计公司|品牌全案VI设计公司 | 液氮罐(生物液氮罐)百科-无锡爱思科 | 恒温油槽-恒温水槽-低温恒温槽厂家-宁波科麦仪器有限公司 |