日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

高可用MySQL MHA介绍

發(fā)布時(shí)間:2025/3/15 数据库 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 高可用MySQL MHA介绍 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

MySQL MHA介紹

MHA簡(jiǎn)介

MHA是一位日本MySQL大牛用Perl寫一套MySQL故障切換方案,來(lái)保證數(shù)據(jù)庫(kù)系統(tǒng)的高可用,在宕機(jī)的事件內(nèi)(通常10-30秒),完成故障轉(zhuǎn)意,部署MHA,可避免主從一致性問(wèn)題,節(jié)約購(gòu)買新服務(wù)器的費(fèi)用,不影響服務(wù)器性能,易安裝,不改變現(xiàn)有部署

MHA在生產(chǎn)環(huán)境的作用

一主多從的環(huán)境下,MySQL的主從復(fù)制是異步或是半同步。 Master發(fā)生故障的時(shí)候,有可能一部分(或者全部)的Slave未能獲取到最新的binlog,造成Slave之間的binlog轉(zhuǎn)發(fā)發(fā)生偏差。 如下圖所示,Master宕機(jī)之后,id=102的binlog未能被發(fā)送到任何一個(gè)Slave上,id=101的binlog只有save2上有,slave3上未能收到id=100和id-101的binlog 如果想要正確恢復(fù):
  • Master必須發(fā)出的ID=102的binlog
  • 還要消除各個(gè)Slave之間的差異性
MHA可以全自動(dòng)的處理以上這些

MHA架構(gòu)

可實(shí)現(xiàn)master工作狀態(tài)的監(jiān)控以及宕機(jī)時(shí)的故障轉(zhuǎn)移 要求:MySQL版本要在5.0以上

MHA原理

1、等待SQL線程執(zhí)行完畢 2、解析最新的Slave上的中繼日志(relay log)的日志頭(log Header),為其他各個(gè)服務(wù)器確定出差異位置 3、將i1–>i2–>X 全部組成一個(gè)二進(jìn)制日志

MHA的主要特性

  • 從master的監(jiān)控到故障轉(zhuǎn)移全部都能自動(dòng)完成,故障轉(zhuǎn)移也可手動(dòng)執(zhí)行
  • 可在秒級(jí)單位內(nèi)實(shí)現(xiàn)故障轉(zhuǎn)移
  • 可將任意Slave提升至master
  • 具備在多個(gè)點(diǎn)上調(diào)用外部腳本(擴(kuò)展)的技能,可以用在電源OFF或者IP地址的故障轉(zhuǎn)移上。
  • 安裝和卸載不用停止當(dāng)前的mysql進(jìn)程
  • MHA 自身不會(huì)增加服務(wù)器負(fù)擔(dān),不會(huì)降低性能,不用追加服務(wù)器
  • 不依賴Storage Engine
  • 不依賴二進(jìn)制文件的格式(不論是statement模式還是Row模式)

拓展性

  • seconary_check_script
  • ? 調(diào)用該腳本,從多個(gè)網(wǎng)絡(luò)路徑判斷MASTER是否宕機(jī)
  • ? MASTER連接錯(cuò)誤時(shí)會(huì)被調(diào)用
  • ? MHA標(biāo)配的腳本masterhaseconarycheck方便
    • shutdown_script
  • ? 電源強(qiáng)制OFF等
  • ? 故障轉(zhuǎn)移前的瞬間被調(diào)用
  • ? SSH可以鏈接到的情況下mysqld,mysqld_safe強(qiáng)制kill,ssh連不到的情況下關(guān)閉電源
    • master_ip_failover_script
  • ??MASTER的IP地址更新,新建和應(yīng)用程序連接所需要的用戶
  • ? 故障轉(zhuǎn)移前的瞬間和轉(zhuǎn)移到新MASTER(差異反映結(jié)束后)被調(diào)用
  • ? 根據(jù)用途的不同來(lái)寫腳本可以實(shí)現(xiàn)不需要更改應(yīng)用程序端就可以連接到新的MASTER
  • ? MASTER IP使用虛擬IP的場(chǎng)合
  • ? 將VIP讓給新的MASTER 5.???用catalog database等來(lái)管理MASTER的IP地址的場(chǎng)合?? ?? 更新該catalog database 中的信息
    • ?report_script 發(fā)郵件通知故障轉(zhuǎn)移成功或失敗等的詳細(xì)情況
  • ? 故障轉(zhuǎn)移結(jié)束后被調(diào)用
  • 案例分析

    • 在DeNA的服務(wù)中(主要是社交游戲),針對(duì)有超過(guò)150組(對(duì))MASTER/SLAVE的服務(wù)器引入MHA
    • MySQL一般不會(huì)出現(xiàn)服務(wù)宕機(jī),通常是由OS和H/W故障引起
    • 拓展

    ??? 檢測(cè)MASTER是否宕機(jī)

    除了Manager會(huì)對(duì)MASTER進(jìn)行監(jiān)控外,另外還通過(guò)其他兩處的遠(yuǎn)程數(shù)據(jù)中心來(lái)檢測(cè)是否可以連接到MASTER

    ??? 強(qiáng)制宕機(jī)MASTER

    ssh可以連接到的情況下用kill -9 mysqld mysqld_safe,ssh連接不到的情況下ipmitool等工具強(qiáng)制關(guān)閉電源。 ?
    • 針對(duì)OS掛掉的故障轉(zhuǎn)移,檢測(cè)系統(tǒng)是否掛掉需要10秒,故障轉(zhuǎn)移僅需4秒
    MASTER的生死判定 3*4-3 (9秒-12秒)

    ? 判定是否可以進(jìn)行故障轉(zhuǎn)移

    默認(rèn)情況,只有其他所有的SLAVE都存貨的情況下才進(jìn)行故障轉(zhuǎn)移 檢測(cè)SLAVE,判斷其工作狀態(tài)(不到1秒)

    ? 故障轉(zhuǎn)移處理

  • 強(qiáng)制將顯著的MASTER關(guān)機(jī)
  • SSH可以連接到的情況下,將有差異的二進(jìn)制日志保存下來(lái)
  • 確定新MASTER
  • 將重新MASTER的IP地址有效化
  • 重開其他的SLAVE從新的MASTER之間的主從復(fù)制
  • 準(zhǔn)備工作

    一個(gè)可以寫的MASTER和多個(gè)SLAVE或只讀MASTER

    當(dāng)MASTER崩潰時(shí),MHA會(huì)修復(fù)SLAVE之間的一致性問(wèn)題。另外,MHA會(huì)嘗試從崩潰的MASTER保存未能發(fā)送的二進(jìn)制日志并應(yīng)用到所有Slave。如果僅有一臺(tái)SLAVE服務(wù)器,就不需要擔(dān)心SLAVE之間的一致性問(wèn)題。但是即使只有一臺(tái)SLAVE服務(wù)器,在SSH可以連通的情況下,MHA在MASTER崩潰時(shí)搶救日志上也會(huì)非常有幫助,當(dāng)然,通過(guò)半同步也可以解決這個(gè)問(wèn)題。 從MHA Manager 0.52 開始支持多個(gè)MASTER(multi master)的復(fù)制。下面是MHA在多MASTER復(fù)制時(shí)注意的事項(xiàng)
    • 只允許有一個(gè)MASTER(可寫)。在其他MASTER上必須設(shè)置MySQL全局變量”read-only=1″
    • 缺省情況下,所有被管理的服務(wù)器(在配置文件中定義的服務(wù)器)應(yīng)該是2層級(jí)聯(lián)復(fù)制。
    在0.52版本以前,MHA僅在所有SLAVE都從同一個(gè)MASTER上進(jìn)行復(fù)制才能進(jìn)行檢測(cè),監(jiān)控和故障轉(zhuǎn)移操作。也就是說(shuō)MHA不支持多主的配置形式。一般情況下,只要MHA可以管控自動(dòng)故障轉(zhuǎn)移,使用多MASTER配置的意義會(huì)很有限,比如在線模式更改。如果只是嘗試使用多MASTER配置(比如僅僅為了在線模式更改)僅需在操作期間停止MHA并配置多主設(shè)置。當(dāng)操作結(jié)束后,重新改為單主多從的配置,并重啟MHA。

    管理3層或更多曾的及聯(lián)復(fù)制環(huán)境

    MHA默認(rèn)不支持三次或更多曾的級(jí)聯(lián)復(fù)制架構(gòu)(比如Master->Master2->Slave3)。MHA僅在SLAVE直接從當(dāng)前主要MASTER進(jìn)行復(fù)制時(shí),才會(huì)進(jìn)行故障轉(zhuǎn)移和恢復(fù)操作。MHA可以管理MASTER1和MASTER2并且當(dāng)MASTER1崩潰提升MASTER為主MASTER,但是MHA不能監(jiān)控和恢復(fù)SLAVE3,因?yàn)镾LAVE3從不同的MASTER(MASTER2)上進(jìn)行主從復(fù)制。為了讓MHA在這種架構(gòu)下能進(jìn)行工作,需要以下設(shè)置:
    • 在MHA的配置文件中設(shè)置MASTER和二層級(jí)聯(lián)中的主機(jī)(MASTER1和MASTER2)
    • 使用multi_tier_slave=1 參數(shù)并在MHA配置文件中設(shè)置所有主機(jī)。
    不管在那種情況中,MHA都只管理主MASTER和第二層的級(jí)聯(lián)SLAVE,即使MASTER崩潰,MASTER2會(huì)成為主要MASTER,從MASTER進(jìn)行復(fù)制的SLAVE依然可以運(yùn)行

    MySQL5.0或更高的版本

    MHA支持MySQL5.0或更高的版本。MHA不支持MySQL4.1,因?yàn)镸ySQL5.0開始,二進(jìn)制日志的格式發(fā)生了改變(binlog v4) MHA分析二進(jìn)制日志并確定位置點(diǎn)時(shí)止支持v4版本,所以MySQL4.1 在這里不能工作。MySQL5.0或更高版本中的mysqlbinlog同樣也需要v4版本的binlog格式。在早起的MySQL版本中主從復(fù)制處理存在一些非常嚴(yán)重的問(wèn)題,所以高度推薦使用高版本的MySQL.特別是如果你還在使用MYSQL 5.06.0 以前的版本,請(qǐng)考慮升級(jí)

    在候選MASTER 上必須開啟log-bin

    如果當(dāng)前SLAVE未設(shè)置log-bin,很明顯他們都不能成為MASTER,MHA Manager內(nèi)部將會(huì)檢查log-bin的設(shè)置,不會(huì)將未開啟binlog的Slave提升為MASTER、如果當(dāng)前的Slave都沒(méi)有設(shè)置log-bin,MHA將會(huì)不盡興故障轉(zhuǎn)移

    在所有服務(wù)器上二進(jìn)制日志和中繼日志過(guò)濾規(guī)則必須一致

    所有服務(wù)器上的主從復(fù)制過(guò)濾規(guī)則(binlog-do-db,replicate-ignore-db等)MHA在啟動(dòng)時(shí)檢查過(guò)濾規(guī)則,如果發(fā)現(xiàn)各服務(wù)器之間的配置不一致將不會(huì)進(jìn)行監(jiān)控或故障轉(zhuǎn)移

    在被選MASTER上必須存在具有復(fù)制權(quán)限的用戶

    當(dāng)故障轉(zhuǎn)移完成后,所有Slave將執(zhí)行CHANGE MASTER TO 語(yǔ)句。必須存在一個(gè)具有復(fù)制權(quán)限的用戶才能進(jìn)行復(fù)制

    總結(jié)

    以上是生活随笔為你收集整理的高可用MySQL MHA介绍的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。