搭建Keepalived + Nginx + Tomcat的高可用負載均衡架構

發表於2017-12-18

1 概述

初期的網際網路企業由於業務量較小,所以一般單機部署,實現單點訪問即可滿足業務的需求,這也是最簡單的部署方式,但是隨著業務的不斷擴大,系統的訪問量逐漸的上升,單機部署的模式已無法承載現有的業務量,需要進行服務叢集化部署,本文主要介紹服務端Tomcat多例項部署,以及如何保證web服務的高可用方案。

  • Nginx 是一個高效能的 HTTP反向代理伺服器
  • Keepalived 是一個基於VRRP協議來實現的LVS服務高可用方案,可以利用其來避免服務的單點故障
  • Tomcat 是一個免費的開放原始碼的Web 應用伺服器,屬於輕量級應用伺服器。

2 Nginx的高可用負載均衡架構

如下圖:為典型的Tomcat服務多例項部署的架構圖

搭建Keepalived + Nginx + Tomcat的高可用負載均衡架構

(1)使用者通過域名請求到DNS,由DNS解析域名後返回對應的IP地址,該IP及為Keepalived對映伺服器的虛擬IP

(2)通過該虛擬IP訪問到對應的負載均衡器(Nginx),這裡Nginx部署兩個,然後通過Keepalived來保證NG的高可用,正常情況下由Keepalived-M將虛擬IP對映轉發至Nginx-M,如果Nginx-M出現故障,此時Keepalived會切換至Keepalived-S開始工作,從而保證了NG的單點故障問題。

(3)通過Nginx負載均衡器,將請求路由到對應的Tomcat服務。

3 搭建Keepalived + Nginx + Tomcat的高可用負載均衡架構

3.1 需要準備的軟體

(1)apache-tomcat-8.5.16.tar.gz

(2)nginx-1.12.2.tar.gz

(3)keepalived-1.3.9.tar.gz

3.2 伺服器準備

兩臺伺服器如:192.168.10.11,192.168.10.12

3.3 安裝需要的依賴包

3.4 安裝

3.4.1 安裝Tomcat

(1)分別在兩臺伺服器中安裝Tomcat,解壓apache-tomcat-8.5.16.tar.gz及可完成安裝。

3.4.2 安裝Nginx

(1)解壓安裝包:tar -zxvf nginx-1.12.2.tar.gz

(2)進入到nginx-1.12.2目錄:cd nginx-1.12.2

(3)編譯:

a) ./configure –with-http_stub_status_module –with-http_ssl_module  –prefix=/usr/local/nginx

b) sudo make && sudo make install

3.4.3 安裝Keepalived

(1)解壓安裝包:tar -zxvf keepalived-1.3.9.tar.gz

(2)進入到keepalived-1.3.9目錄:cd keepalived-1.3.9

(3)執行編譯:

a)./configure –prefix=/usr/local/keepalived –sysconf=/etc

b)sudo make && sudo make install

3.5 配置

3.5.1 分別配置兩臺伺服器的Nginx

(1)分別修改兩臺伺服器nginx配置檔案,vi /usr/local/nginx/conf/nginx.conf

(2)內容如下:

3.5.2 主Keepalived配置

(1)修改11伺服器的keepalived配置檔案,vi /etc/keepalived/keepalived.conf

(2)內容如下:

3.5.3 備Keepalived配置

(1)修改12伺服器的keepalived配置檔案,vi /etc/keepalived/keepalived.conf

(2)內容如下:

3.5.4 Nginx狀態檢查指令碼建立

(1)新建Nginx的狀態檢查指令碼:check_nginx.sh

(2)內容如下:

4 執行測試

(1)為了更直觀的檢視到keepalived切換的效果,將11伺服器中的nginx的upstream服務只配置11的tomcat服務地址,12伺服器中的upstream服務只配置12的tomcat服務地址,這樣只需要觀察將11伺服器中的nginx關閉看使用虛擬ip是否可以訪問到12伺服器的tomcat。

(2)分別啟動兩個伺服器中的tomcat、nginx、keepalived,訪問虛擬ip:192.168.10.200,可以檢視到訪問的是主keepalived伺服器的tomcat

搭建Keepalived + Nginx + Tomcat的高可用負載均衡架構

(3)關閉11伺服器的nginx,nginx -s stop,再次訪問虛擬ip,如下:說明主keepalived通過配置的指令碼檢測到了本服務的nginx服務掛掉了,所以立馬切換至了備的keepalived,這時12伺服器的keepalived升為了主,所以就訪問到了12伺服器的tomcat。

搭建Keepalived + Nginx + Tomcat的高可用負載均衡架構

相關文章