Keepalived實現雙機熱備

来源:http://www.cnblogs.com/quanzhiguo/archive/2017/09/14/7519952.html
-Advertisement-
Play Games

Keepalived實現雙機熱備: 雙機熱備一般指的是兩台機器設備同時在運行,但是只有一臺處於提供服務的狀態。當其中一臺設備出現故障,那麼另一臺設備接管角色,繼續提供服務,他們之間的切換時間非常之短,基本是無縫切換,所以避免了因為某台伺服器出現故障,導致系統軟體不能正常運行的問題。 · Keepal ...


Keepalived實現雙機熱備:

雙機熱備一般指的是兩台機器設備同時在運行,但是只有一臺處於提供服務的狀態。當其中一臺設備出現故障,那麼另一臺設備接管角色,繼續提供服務,他們之間的切換時間非常之短,基本是無縫切換,所以避免了因為某台伺服器出現故障,導致系統軟體不能正常運行的問題。

 

·     Keepalived

·     熱備架構圖

·     安裝及配置

·     測試及驗證

 

一、Keepalived

Keepalived的運行原理是基於VRRP(虛擬路由冗餘協議)機制,在VRRP中有兩個重要的概念:VRRP路由器和虛擬路由器,主控路由器和備份路由器。

 

VRRP路由器是一種實體路由器設備,而虛擬路由器則是基於VRRP協議構建的虛擬路由器,是軟性的虛擬概念,一組VRRP路由器協同工作,共同構造一臺虛擬伺服器。

 

VRRP協議支持一種選舉機制,主要用來選出用來提供服務的路由即主控路由,其它的就是備份路由了,當主控路由失效之後,備份路由中重新選出一個主控路由(往往按照設置好的優先順序別重新分配),接管主控服務,繼續工作,來保證不間斷的提供服務。

 

二、熱備架構圖

1、環境準備

因為資源條件限制,這裡使用虛擬機代替物理主機,具體如下:

master : 192.168.132.10(主控伺服器)

backup : 192.168.132.11(備用伺服器)

vip : 192.168.132.101

 

2、架構圖解

 

NOTE:

Vip:虛擬伺服器;

Node A:物理主伺服器;

Node B:物理備用伺服器;

 

在這種模式下,虛擬IP某一時刻只能屬於一個物理節點,另一個作為備份節點存在,當主節點不可用時,備份節點接管虛擬IP,繼續提供正常的服務。

 

3、Keepalived的原理

Keepalived被安裝在兩台物理伺服器上,並且彼此監控對方當前是否處於正常狀態,當Node A正常時,其上的keepalived會發送廣播:192.168.132.101 這個ip對應的節點為Node A的網卡MAC地址;反之,如果NodeB正常時,其上的keepalived也會發送廣播:192.168.132.101這個ip對應的節點為Node B的網卡MAC地址;此時,相關的電腦及客戶端的ARP會發生更新,對應192.168.132.11的MAC地址與Node B網卡的MAC地址相同。

 

三、安裝及配置

1、虛擬IP配置

$vim /etc/sysconfig/network-scripts/ifcfg-eth2:0

 

DEVICE=eth2:0  

TYPE=Ethernet  

ONBOOT=yes  

BOOTPROTO=static  

DNS1=192.168.232.2  

IPADDR=192.168.132.101 

NETMASK=255.255.255.0  

GETWAY=192.168.232.2

 

2、主備機器安裝keepalived

$tar  -zxvf  keepalived-1.2.6.tar.gz

$cd keepalived-1.2.6

$sudo ./configure

$make & make install

 

3、主節點keepalived配置

global_defs {

   router_id NodeA

}

 

vrrp_instance VI_11 {

   state MASTER   #設置為主伺服器

   interface eth2 #設置監聽網路介面

   priority 101   #設置優先順序,值越大代表優先順序越高

   advert_int 1   #設置VRRP廣播周期秒數

   authentication {

      auth_type PASS #VRRP認證方式,主備必須一致

      auth_pass 1234 #驗證密碼

  }

   virtual_router_id 52 #主備必須一致

}

 

virtual_ipaddress {

   192.168.132.101/24  #VRRP HA虛擬地址

}

 

4、備用節點keepalived配置

global_defs {

   router_id NodeB

}

 

vrrp_instance VI_11 {

   state BACKUP   #設置為備用伺服器

   interface eth2 #設置監聽網路介面

   priority 100   #設置優先順序,值越大代表優先順序越高

   advert_int 1   #設置VRRP廣播周期秒數

   authentication {

      auth_type  PASS #VRRP認證方式,主備必須一致

      auth_pass 1234 #驗證密碼

   }

   virtual_router_id 52 #主備必須一致

}

 

virtual_ipaddress {

   192.168.132.101/24  #VRRP HA虛擬地址

}

 

5、啟動主備keepalived服務

$keepalived  -D –f  /etc/keepalived/keepalived.conf

 

查看logs日誌:

$tail  -f  /var/log/messages

通過日誌,可以查看節點的ARP消息daemon[4029]: 

Registering new address record for192.168.132.101 on eth0.

 

6、安裝web伺服器

在兩台物理伺服器上安裝web伺服器,比如:nginx,apacache或tomcat等,在這裡省略,請自行查閱資料安裝。

 

四、測試及驗證

1、在Node A節點上創建一個html文件,內容如下:

this is the test page

<br/>

from server 192.168.132.10

 

訪問:

通過訪問http://192.168.132.101/test/test/html

 

2、在Node B節點上創建一個html文件,內容如下:

this is the test page

<br/>

from server 192.168.132.11

 

訪問:

通過訪問http://192.168.132.11/test/test/html訪問是可以訪問的,但是在Node A正常情況下,訪問http://192.168.132.101/test/test/html是訪問的Node A節點。

 

3、驗證Node B節點的可用性

首先,將節點A的keepalived伺服器關閉來模擬故障:

$killall  keepalived

 

其次,通過下麵的Url訪問:

http://192.168.132.101/test/test.html

那麼訪問的就是Node B節點了,內容:

this is the test page

<br/>

from server 192.168.132.11

 

4、查看日誌

此時查看日誌,會發現Node B現在為主節點,發送ARP廣播信息。而當Node A恢復之後,Node B釋放角色,將繼續由Node A為主伺服器,繼續服務。

daemon[3769]: 

Registering new address record for 192.168.132.101 on eth0.

 

NOTE:

這裡只介紹使用keepalived實現雙機熱備的功能和流程,至於Web伺服器的安裝等輔助技術,這裡不做介紹。

 

 

附加:

一般情況下,主備伺服器的選型是不同的,也就是主伺服器要高配,因為其會被經常使用,出現故障只是特殊情況,而備用伺服器是為了保證伺服器的持續服務,但是最終還是要恢復並使用主伺服器來作為主控路由伺服器,也是為了縮小不必要的開銷的考慮。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 筆者每當遇到一個新事物的想去瞭解的時候,總是會問上自己第一個問題,這個新事物是乾什麼用的?在解釋我所理解的REST這個過程中也不例外,這篇博客我們先關註一下REST是乾什麼用的,然後後續再解釋REST是什麼。好了,不說廢話了,在上篇結尾處說到,REST是Web的架構風格,暫且不管REST和Web,我 ...
  • 【卻說那七衣仙女自受了大聖的定身法術,一周天方能解脫,各提花籃,回奏王母說道:“齊天大聖使術法困住我等,故此來遲。”王母問道:“汝等摘了多少蟠桃?”仙女道:“只有兩籃小桃,三籃中桃。至後面,大桃半個也無,想都是大聖偷吃了。及正尋間,不期大聖走將出來,行凶拷打,又問設宴請誰。我等把上會事說了一遍,他就 ...
  • ?useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false ...
  • 【大聖看玩多時,問土地道:“此樹有多少株數?”土地道:“有三千六百株。前面一千二百株,花微果小,三千年一熟,人吃了成仙了道,體健身輕。中間一千二百株,層花甘實,六千年一熟,人吃了霞舉飛升,長生不老。後面一千二百株,紫紋緗核,九千年一熟,人吃了與天地齊壽,日月同庚。”大聖聞言,歡喜無任,當日查明瞭株樹 ...
  • 目前已定義的java設計模式細分下來有二十餘種,這篇博客主要是想從大家所熟知的孫悟空入手,闡述各個設計模式的概念和優缺點,以及他們之間的聯繫。 在下麵介紹的每個設計模式里,都會有與孫悟空相關的具體案例,主要是為了方便大家理解與記憶,否則使用一些枯燥的例子,很難讓人印象深刻。 按筆者的理解,設計模式的 ...
  • 1目的 規範開發模式過程,指導項目研發、質控測試、DevOps的相關活動。 2適用範圍 本規範的作用範圍是為互聯網軟體產品相關項目開發模式的管理過程。 (1) 對項目團隊中研發人員在開發模式過程中的活動、職責等方面進行了指導; (2) 對項目團隊中質控測試在開發模式過程中的活動、職責等方面進行了指導 ...
  • MySQL應用軟體以及環境安裝(Navicat軟體) 百度雲盤鏈接分享: 鏈接: https://pan.baidu.com/s/1o8UMiro 密碼: 8pdu ...
  • 定義: 定義一個操作中演算法的框架,而將一些步驟延遲到子類中。模板方法模式使得子類可以不改變一個演算法的結構即可重定義該演算法的某些特定步驟。 UML類圖: 具體代碼: 模塊說明: AbstractClass:抽象類,定義整個流程演算法的骨架。ConcreteClass:具體類,實現流程演算法里的具體步驟。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...