Net分散式系統之三:Keepalived+LVS+Nginx負載均衡之高可用

来源:http://www.cnblogs.com/Andon_liu/archive/2016/04/12/5380848.html
-Advertisement-
Play Games

上一篇寫了nginx負載均衡,此篇實現高可用(HA)。系統整體設計是採用Nginx做負載均衡,若出現Nginx單機故障,則導致整個系統無法正常運行。針對系統架構設計的高可用要求,我們需要解決Nginx負載均衡出現單機故障時,系統正常運行的需求。所以系統架構引入Keepalived組件,實現系統高可用 ...


  上一篇寫了nginx負載均衡,此篇實現高可用(HA)。系統整體設計是採用Nginx做負載均衡,若出現Nginx單機故障,則導致整個系統無法正常運行。針對系統架構設計的高可用要求,我們需要解決Nginx負載均衡出現單機故障時,系統正常運行的需求。所以系統架構引入Keepalived組件,實現系統高可用。

  一、Keepalived介紹

   Keepalived是分散式部署系統解決系統高可用的軟體,結合LVS(Linux Virtual Server)使用,其功能類似於heartbeat,解決單機宕機的問題。

 


 

  二、Keepalived技術原理

   keepalived是以VRRP協議為實現基礎的,VRRP全稱Virtual Router Redundancy Protocol,即虛擬路由冗餘協議。通過VRRP協議結合LVS,對組群伺服器監控情況,若master出現宕機情況,則將VIP漂移到backup機上。實現了分散式系統高可用。可以理解為:keepalived是LVS的管理軟體,根據監控情況,將宕機伺服器從ipvsadm移除掉。

 


 

  三、Keepalived+LVS+Nginx實現系統高可用

  

 
伺服器 IP地址 說明
虛擬IP 192.168.1.120:80  
主機 192.168.1.104:80  
備機 192.168.1.103:80  
Web站點A 192.168.1.101:8081 不同埠
Web站點B 192.168.1.101:8082 不同埠

 

 

  

 

 

  1、安裝ipvsadm,CentOS7自帶安裝包,通過yum進行安裝。實現系統支持LVS

yum install ipvsadm

  2、安裝Keepalived軟體,並將keepalived設置開機啟動

yum install Keepalived
systemctl enable keepalived

  

  3、進行Keepalived.conf配置,如果是MASTER機,將state BACKUP改為state MASTER。

vim /etc/keepalived/keepalived.conf
#配置的內容
! Configuration File for keepalived

global_defs {
   notification_email {
     [email protected] #收到通知的郵件地址
   }
   notification_email_from [email protected]
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
}

vrrp_script monitor_nginx{
   script "/usr/local/etc/keepalived/script/monitor_nginx.sh"
   interval 1
   weight -15
}

vrrp_instance VI_1 {
    state BACKUP 
    interface eno16777736 
    virtual_router_id 51
    priority 80
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.1.120
    }
    track_script {
        monitor_nginx
    }
}

virtual_server 192.168.1.120 80 {
    delay_loop 6
    lb_algo wrr 
    lb_kind DR
    persistence_timeout 50
    protocol TCP

    real_server 192.168.1.103 80 {
        weight 1
        TCP_CHECK {
            connect_timeout 10
            nb_get_retry 3
            delay_before_retry 3
            connect_port 80
        }
    }

    real_server 192.168.1.104 80 {
        weight 5
        TCP_CHECK {
            connect_timeout 10
            nb_get_retry 3
            delay_before_retry 3
            connect_port 80
        }
    }
}

  4、配置監控shell腳本

(1)創建:vim /usr/local/etc/keepalived/script/monitor_nginx.sh

(2)SHELL文件內容
#!/bin/bash if [ "$(ps -ef | grep "nginx: master process"| grep -v grep )" == "" ] then systemclt start nginx.service sleep 5 if [ "$(ps -ef | grep "nginx: master process"| grep -v grep )" == "" ] then killall keepalived fi fi

  以上完成相關配置,nginx和web服務以上一篇博客內容一致。如下對功能進行驗證測試。

 


 

  四、實現測試展示

   1、訪問系統情況:通過VIP(192.168.1.120)訪問系統頁面。因為設置了輪詢調度,所以刷新頁面訪問不同站點。

        

 

  2、將 MASTER(192.168.1.104)關機前後,查看相關VLS情況:

  (1)關機前:

  (2)關機後:

  我們看到將104伺服器從 LVS移除掉。此時則將後續請求轉發到103伺服器。

 

  3、關機後,BACKUP伺服器 keepalived日誌顯示無法連接104,並移除掉

  

  5、開機後,將自動檢測到伺服器正常,並加入LVS中。

  

 

作者:andon
出處:http://www.cnblogs.com/Andon_liu
關於作者:專註於微軟平臺項目架構、管理。熟悉設計模式、領域驅動、架構設計、敏捷開發和項目管理。現主要從事ASP.NET MVC、WCF/Web API、SOA、MSSQL、redis方面的項目開發、架構、管理工作。 如有問題或建議,請一起學習討論!
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接。
如有問題,可以郵件:[email protected] 聯繫我,謝謝。

 


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

-Advertisement-
Play Games
更多相關文章
  • Atitit.prototype-base class-based 基於“類” vs 基於“原型” 1. 基於“類” vs 基於“原型”1 2. 對象的產生有兩種基本方式。一種是以原型(prototype)對象為基礎產生新的對象。一種是以類(class)為基礎產生新對象1 3. 基於類(class- ...
  • Atitit.判斷漢字的編碼 regedit 註冊表裡面的reg_sz 1. 可以判斷出是unicode編碼1 2. 有下麵分割ucs2 大頭小偷編碼1 3. 使用小偷編碼測試1 4. 註冊表裡面的reg_dword讀取2 1. 可以判斷出是unicode編碼 byte[] ai={44, 103, ...
  • Atitit。Js調用後臺語言 java c# php swing android swt的方法大總結 1. Js調用後臺語言有三種方法1 2. Swt BrowserFunction 綁定方法1 3. Android webview 可以綁定對象1 4. Js 調用Java Nashorn引擎,可 ...
  • Atitit.vod 視頻播放系統 影吧系統的架構圖 架構體系 解決方案 1. 運行平臺:跨平臺 android ios pc mobile 1.1. 前端 界面 1.2. Web組件化 Js css html的動態載入 ,容器化運行,ajax iframe 1.3. Css icon類庫 1.4. ...
  • 裝飾模式(Decorator) 定義 裝飾模式(Decorator),動態地給一個對象添加一些額外的職責,就增加功能來說,裝飾模式比生成子類更為靈活。 類圖 描述 Component:被裝飾者和裝飾者共有的基類; ConcreteComponent:被裝飾者的具體類; Decorator:裝飾類,包 ...
  • 編者按 與傳統意義上的紅包相比,近兩年火起來的“紅包”,似乎才是如今春節的一大重頭戲。歷經上千年時代傳承與變遷,春節發紅包早已成為歷史沉澱的文化習俗,融入了民族的血脈。按照各家公佈的數據,除夕全天微信用戶紅包總發送量達到80.8億個,紅包峰值收發量為40.9萬個/秒。春晚直播期間討論春晚的微博達到5 ...
  • 在配置cat集群時,有一些設置是我們應該註意的,從它的部署文檔中我們可以看到相關信息,但說的還不夠明確和重要,大叔今天總結一下Cat集群配置的註意事項 1 服務端datasources.xml用來設置連接的mysql,集群里的伺服器對這項配置是相同的 2 服務端的server.xml,用來設置集群里 ...
  • 在之前發佈Objective-C系列博客的時候,其中提到過OC的通知機制,請參考《Objective-C中的老闆是這樣發通知的(Notification)》這篇博客。在之前關於Notification的博客中,只介紹了Foundation框架中的通知的使用方式。正如前面博客中提到的那樣,通知是“一對 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...