java程式設計—如何搭建Keepalived+Nginx+Tomcat高可用負載均衡架構
一.概述
初期的網際網路企業由於業務量較小,所以一般單機部署,實現單點訪問即可滿足業務的需求,這也是最簡單的部署方式,但是隨著業務的不斷擴大,系統的訪問量逐漸的上升,單機部署的模式已無法承載現有的業務量,需要進行服務叢集化部署,本文主要介紹服務端Tomcat多例項部署,以及如何保證web服務的高可用方案。
- Nginx 是一個高效能的 HTTP反向代理伺服器
- Keepalived 是一個基於VRRP協議來實現的LVS服務高可用方案,可以利用其來避免服務的單點故障
- Tomcat 是一個免費的開放原始碼的Web 應用伺服器,屬於輕量級應用伺服器。
二. 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服務。
想要學習Java高架構、分散式架構、高可擴充套件、高效能、高併發、效能優化、Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分散式專案實戰學習架構師視訊免費獲取
架構群;468947140
三. 搭建Keepalived + Nginx + Tomcat的高可用負載均衡架構
- 需要準備的軟體
- (1)apache-tomcat-8.5.16.tar.gz
- (2)nginx-1.12.2.tar.gz
- (3)keepalived-1.3.9.tar.gz
2.伺服器準備
兩臺伺服器如:192.168.10.11,192.168.10.12
3.安裝需要的依賴包
$ yum -y install gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel open openssl-devel
4.安裝
4.1 安裝Tomcat
(1)分別在兩臺伺服器中安裝Tomcat,解壓apache-tomcat-8.5.16.tar.gz及可完成安裝。
4.2 安裝Nginx
- (1)解壓安裝包:tar -zxvf nginx-1.12.2.tar.gz
- (2)進入到nginx-1.12.2目錄:cd nginx-1.12.2
- (3)編譯:
$ ./configure –with-http_stub_status_module –with-http_ssl_module –prefix=/usr/local/nginx
$ sudo make && sudo make install
4.3 安裝Keepalived
- (1)解壓安裝包:tar -zxvf keepalived-1.3.9.tar.gz
- (2)進入到keepalived-1.3.9目錄:cd keepalived-1.3.9
- (3)執行編譯:
$ ./configure –prefix=/usr/local/keepalived –sysconf=/etc
$ sudo make && sudo make install
5 配置
5.1 分別配置兩臺伺服器的Nginx
- (1)分別修改兩臺伺服器nginx配置檔案,vi /usr/local/nginx/conf/nginx.conf
- (2)內容如下:
#nginx程式數
worker_processes 1;
#單個程式最大連線數
events {
worker_connections 1024;
}
#http伺服器配置
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
#長連線超時時間,單位是秒
keepalive_timeout 65;
#upstream負載均衡配置,配置路由到tomcat的服務地址以及權重
upstream localhost{
server 192.168.10.11:8080 weight=2;
server 192.168.10.12:8080 weight=2;
}
#虛擬主機的配置
server {
#監聽埠
listen 80;
#域名可以有多個,用空格隔開
server_name localhost;
location / {
root html;
index index.html index.htm;
#nginx跟後端伺服器連線超時時間(代理連線超時)
proxy_connect_timeout 3;
#後端伺服器資料回傳時間(代理髮送超時)
proxy_send_timeout 30;
#連線成功後,後端伺服器響應時間(代理接收超時)
proxy_read_timeout 30;
proxy_pass http://localhost;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
5.2 主Keepalived配置
- (1)修改11伺服器的keepalived配置檔案,vi /etc/keepalived/keepalived.conf
- (2)內容如下:
! Configuration File for keepalived
#全域性配置
global_defs {
#keepalived切換的時候,發訊息到指定的email,可配置多個email
notification_email {
feinik1@foxmail.com
feinik2@foxmail.com
}
#通知郵件從哪個地址發出
notification_email_from feinik@foxmail.com
#通知郵件的smtp地址
smtp_server smtp.exmail.qq.com
#連線smtp伺服器的超時時間,單位秒
smtp_connect_timeout 30
#Keepalived的機器標識,一個網路內保持唯一
router_id nginx-master
}
#執行指令碼配置
vrrp_script chk_nginx {
#指令碼所在路徑
script “/home/project/keepalived/check_nginx.sh”
#指令碼執行間隔時間,秒
interval 2
#優先順序
weight 2
}
#keepalived例項配置
vrrp_instance VI_1 {
#指定例項的初始狀態,MASTER或BACKUP兩種狀態,並且需要大寫
state MASTER
#例項繫結的網路卡
interface ens33
#虛擬路由標識,是一個數字,整個VRRP內唯一,如果keepalived配置了主備,需要相同
virtual_router_id 51
#優先順序,數值愈大,優先順序越高
priority 100
#MASTER與BACKUP之間同步檢查的時間間隔,單位為秒
advert_int 1
#通訊驗證
authentication {
auth_type PASS
auth_pass feinik
}
#追蹤外圍指令碼
track_script {
#這裡配置vrrp_script的名稱
chk_nginx
}
#虛擬ip配置,可配置多個
virtual_ipaddress {
192.168.10.200
}
}
5.3 備Keepalived配置
- (1)修改12伺服器的keepalived配置檔案,vi /etc/keepalived/keepalived.conf
- (2)內容如下:
! Configuration File for keepalived
#全域性配置
global_defs {
#keepalived切換的時候,發訊息到指定的email,可配置多個email
notification_email {
feinik1@foxmail.com
feinik2@foxmail.com
}
#通知郵件從哪個地址發出
notification_email_from feinik@foxmail.com
#通知郵件的smtp地址
smtp_server smtp.exmail.qq.com
#連線smtp伺服器的超時時間,單位秒
smtp_connect_timeout 30
#Keepalived的機器標識,一個網路內保持唯一
router_id nginx-master
}
#執行指令碼配置
vrrp_script chk_nginx {
#指令碼所在路徑
script “/home/project/keepalived/check_nginx.sh”
#指令碼執行間隔時間,秒
interval 2
#優先順序
weight 2
}
#keepalived例項配置
vrrp_instance VI_1 {
#指定例項的初始狀態,MASTER或BACKUP兩種狀態,並且需要大寫
state BACKUP
#例項繫結的網路卡
interface ens33
#虛擬路由標識,是一個數字,整個VRRP內唯一,如果keepalived配置了主備,需要相同
virtual_router_id 51
#優先順序,數值愈大,優先順序越高
priority 99
#MASTER與BACKUP之間同步檢查的時間間隔,單位為秒
advert_int 1
#通訊驗證
authentication {
auth_type PASS
auth_pass feinik
}
#追蹤外圍指令碼
track_script {
#這裡配置vrrp_script的名稱
chk_nginx
}
#虛擬ip配置,可配置多個
virtual_ipaddress {
192.168.10.200
}
}
5.4 Nginx狀態檢查指令碼建立
(1)新建Nginx的狀態檢查指令碼:check_nginx.sh
(2)內容如下:
#!/bin/sh
NGINX=/usr/common/nginx/sbin/nginx
PORT=80
nmap localhost -p $PORT | grep “$PORT/tcp open”
#echo $?
if [ $? -ne 0 ];then
$NGINX -s stop
#這裡再次嘗試啟動NG
$NGINX
sleep 5
nmap localhost -p $PORT | grep “$PORT/tcp open”
[ $? -ne 0 ] && cd /usr/common/keepalived/sbin && pkill keepalived
echo “stoped”
fi
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
- image.png
- (3)關閉11伺服器的nginx,nginx -s stop,再次訪問虛擬ip,如下:說明主keepalived通過配置的指令碼檢測到了本服務的nginx服務掛掉了,所以立馬切換至了備的keepalived,這時12伺服器的keepalived升為了主,所以就訪問到了12伺服器的tomcat。
歡迎大家加入架構群:468947140
本群提供免費的學習指導 架構資料 以及免費的解答
不懂得問題都可以在本群提出來 還會有職業生涯規劃以及面試指導
進群修改群備註:開發年限-地區-經驗
方便架構師解答問題
相關文章
- Keepalived+Nginx+Tomcat配置高可用負載均衡系統示例NginxTomcat負載
- keepalived高可用負載均衡負載
- Nginx負載均衡高可用Nginx負載
- 基於MySQL Cluster + LVS + KeepAlived部署負載均衡高可用架構MySql負載架構
- 3.RabbitMQ高階叢集搭建(Haproxy負載均衡、Keepalived高可用)MQ負載
- Keepalived實現Nginx負載均衡高可用Nginx負載
- CentOS7+ keepalived+ haproxy搭建Mycat高可用及負載均衡CentOS負載
- 如何做高可用的架構設計?架構
- RabbitMQ(四):使用Docker構建RabbitMQ高可用負載均衡叢集MQDocker負載
- nginx反向大理和負載均衡以及高可用Nginx負載
- LVS+Keepalived 實現高可用負載均衡負載
- Mycat 雙主雙從-負載均衡-高可用負載
- Haproxy+Keepalived高可用負載均衡叢集負載
- haporxy+keepalived實現負載均衡+高可用負載
- MySQL高可用架構設計分析MySql架構
- keepalived+haproxy實現mysql負載均衡高可用MySql負載
- mysql高可用架構MHA搭建MySql架構
- 【DB寶42】MySQL高可用架構MHA+ProxySQL實現讀寫分離和負載均衡MySql架構負載
- LVS+Keepalive 實現負載均衡高可用叢集負載
- 高可用架構設計全面詳解(8大高可用方案)架構
- 微服務架構如何實現客戶端負載均衡微服務架構客戶端負載
- 【Nginx】如何實現Nginx的高可用負載均衡?看完我也會了!!Nginx負載
- mysql負載均衡搭建(haproxy)MySql負載
- Java程式設計解密-Dubbo負載均衡與叢集容錯機制Java程式設計解密負載
- 架構文摘:LSV負載均衡技術筆記架構負載筆記
- 分散式架構篇 | OceanBase負載均衡的魅力分散式架構負載
- 不懂高效能的負載均衡設計?沒關係,架構師帶你飛負載架構
- 負載均衡簡介與搭建負載
- 高可用架構架構
- 很全!淺談幾種常用負載均衡架構負載架構
- CentOS7 實現 Keepalived + Nginx 實現高可用 Web 負載均衡CentOSNginxWeb負載
- Nginx多種負載均衡策略搭建Nginx負載
- 得物彩虹橋架構演進之路-負載均衡篇架構負載
- Nginx實現請求的負載均衡 + keepalived實現Nginx的高可用Nginx負載
- 億級流量系統架構之如何設計全鏈路99.99%高可用架構【石杉的架構筆記】架構筆記
- MySQL 高可用架構之 MMM 架構MySql架構
- gRPC負載均衡(自定義負載均衡策略)RPC負載
- gRPC負載均衡(客戶端負載均衡)RPC負載客戶端