HA叢集中的腦裂問題解決方案
在“雙機熱備”高可用(HA)系統中,當聯絡2個節點的“心跳線”斷開時,本來為一整體、動作協調的HA系統,就分裂成為2個獨立的個體。由於相互失去了聯絡,都以為是對方出了故障,
2個節點上的HA軟體像“裂腦人”一樣,“本能”地爭搶“共享資源”、爭起“應用服務”,就會發生嚴重後果:或者共享資源被瓜分、2邊“服務”都起不來了;或者2邊“服務”都起來了,
但同時讀寫“共享儲存”,導致資料損壞(常見如資料庫輪詢著的聯機日誌出錯)。
對付HA系統“腦裂”的對策,大概有以下幾條:
1)新增冗餘的心跳線,例如雙線條線。儘量減少“腦裂”發生機會。
2)啟用磁碟鎖。正在服務一方鎖住共享磁碟,“腦裂”發生時,讓對方完全“搶不走”共享磁碟資源。但使用鎖磁碟也會有一個不小的問題,如果佔用共享盤的一方不主動“解鎖”,另一方
就永遠得不到共享磁碟。現實中假如服務節點突然當機或崩潰,就不可能執行解鎖命令。後備節點也就接管不了共享資源和應用服務。於是有人在HA中設計了“智慧”鎖。即,正在服務的一方
只在發現心跳線全部斷開(察覺不到對端)時才啟用磁碟鎖。平時就不上鎖了。
3)設定仲裁機制。例如設定參考IP(如閘道器IP),當心跳線完全斷開時,2個節點都各自ping一下 參考IP,不通則表明斷點就出在本端,不僅“心跳”、還兼對外“服務”的本端網路鏈路斷了,
即使啟動(或繼續)應用服務也沒有用了,那就主動放棄競爭,讓能夠ping通參考IP的一端去起服務。更保險一些,ping不通參考IP的一方乾脆就自我重啟,以徹底釋放有可能還佔用著的那些
共享資源。
2個節點上的HA軟體像“裂腦人”一樣,“本能”地爭搶“共享資源”、爭起“應用服務”,就會發生嚴重後果:或者共享資源被瓜分、2邊“服務”都起不來了;或者2邊“服務”都起來了,
但同時讀寫“共享儲存”,導致資料損壞(常見如資料庫輪詢著的聯機日誌出錯)。
對付HA系統“腦裂”的對策,大概有以下幾條:
1)新增冗餘的心跳線,例如雙線條線。儘量減少“腦裂”發生機會。
2)啟用磁碟鎖。正在服務一方鎖住共享磁碟,“腦裂”發生時,讓對方完全“搶不走”共享磁碟資源。但使用鎖磁碟也會有一個不小的問題,如果佔用共享盤的一方不主動“解鎖”,另一方
就永遠得不到共享磁碟。現實中假如服務節點突然當機或崩潰,就不可能執行解鎖命令。後備節點也就接管不了共享資源和應用服務。於是有人在HA中設計了“智慧”鎖。即,正在服務的一方
只在發現心跳線全部斷開(察覺不到對端)時才啟用磁碟鎖。平時就不上鎖了。
3)設定仲裁機制。例如設定參考IP(如閘道器IP),當心跳線完全斷開時,2個節點都各自ping一下 參考IP,不通則表明斷點就出在本端,不僅“心跳”、還兼對外“服務”的本端網路鏈路斷了,
即使啟動(或繼續)應用服務也沒有用了,那就主動放棄競爭,讓能夠ping通參考IP的一端去起服務。更保險一些,ping不通參考IP的一方乾脆就自我重啟,以徹底釋放有可能還佔用著的那些
共享資源。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-1990057/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- HA腦裂問題解決方案
- Redis運維實戰之叢集中的腦裂Redis運維
- Openstack的HA解決方案【mysql叢集配置】MySql
- ZooKeeper 05 - ZooKeeper 叢集的腦裂問題(Split Brain)AI
- 終於解決 k8s 叢集中部署 nodelocaldns 的問題K8SDNS
- drbd腦裂徹底解決
- 針對負載均衡叢集中的session解決方案的總結負載Session
- 【Redis叢集原理專題】分析一下相關的Redis叢集模式下的腦裂問題!Redis模式
- Oracle RAC叢集腦裂split-brain概述及解決辦法OracleAI
- 教你解決CCE叢集中容器出網
- Openstack的HA解決方案【haproxy和keepalived】
- Oracle 19C RAC腦裂問題分析Oracle
- split-brain 腦裂問題(Keepalived)AI
- Kubernetes EKS 叢集中的 IP 地址分配問題
- 輕鬆解決Github連線緩慢、圖裂問題Github
- Openstack的HA解決方案【替換原有的dashboard】
- 解決叢集 Yellow 與 Red 的問題
- 跨域問題,解決方案 – CORS方案跨域CORS
- 跨域問題,解決方案 - CORS方案跨域CORS
- 銀行前置機(MBFE)集中解決方案
- 木馬問題解決方案
- jive中文問題解決方案
- LB與HA解決方案:nginx+keepalivedNginx
- LB與HA解決方案:haproxy+keepalived
- 玩Deno遇到問題的解決方案
- Nginx跨域的問題解決方案Nginx跨域
- Mycat分片方案需要解決的問題
- git 常見問題的解決方案Git
- 一個小問題的解決方案
- 快速解決電腦噪音問題
- 轉:瞭解Oracle RAC Brain Split Resolution叢集腦裂協議OracleAI協議
- 跨域問題及解決方案跨域
- PHPAjax跨域問題解決方案PHP跨域
- 常見問題及解決方案
- spring security 問題解決方案Spring
- Kafka常見的問題及解決方案Kafka
- 求解決 Laravel with () limit 的問題 附帶解決方案LaravelMIT
- Novell SUSE Linux Enterprise Server10 Oracle HA叢集解決方案LinuxServerOracle