搭建Keepalived + Nginx + Tomcat的高可用負(fù)載均衡架構(gòu)

姓名:榮皓宇

學(xué)號(hào):17101223406

轉(zhuǎn)載自知乎:https://my.oschina.net/feinik/blog/1590941?hmsr=toutiao.io&utm_medium=toutiao.io&utm_source=toutiao.io

【嵌牛導(dǎo)讀】:lnmp和lamp都已經(jīng)介紹過(guò)了。現(xiàn)在介紹下lnamp的部署

【嵌牛鼻子】:lnamp逮栅,負(fù)載均衡

【嵌牛提問(wèn)】:這個(gè)Lnamp部署出來(lái)理論最大容量是多少呢

【嵌牛正文】:

1 概述

初期的互聯(lián)網(wǎng)企業(yè)由于業(yè)務(wù)量較小氨鹏,所以一般單機(jī)部署,實(shí)現(xiàn)單點(diǎn)訪問(wèn)即可滿足業(yè)務(wù)的需求,這也是最簡(jiǎn)單的部署方式犯戏,但是隨著業(yè)務(wù)的不斷擴(kuò)大势腮,系統(tǒng)的訪問(wèn)量逐漸的上升,單機(jī)部署的模式已無(wú)法承載現(xiàn)有的業(yè)務(wù)量烈钞,需要進(jìn)行服務(wù)集群化部署泊碑,本文主要介紹服務(wù)端Tomcat多實(shí)例部署毯欣,以及如何保證web服務(wù)的高可用方案馒过。

Nginx 是一個(gè)高性能的 HTTP反向代理服務(wù)器

Keepalived 是一個(gè)基于VRRP協(xié)議來(lái)實(shí)現(xiàn)的LVS服務(wù)高可用方案,可以利用其來(lái)避免服務(wù)的單點(diǎn)故障

Tomcat 是一個(gè)免費(fèi)的開(kāi)放源代碼的Web 應(yīng)用服務(wù)器酗钞,屬于輕量級(jí)應(yīng)用服務(wù)器腹忽。

2 Nginx的高可用負(fù)載均衡架構(gòu)

如下圖:為典型的Tomcat服務(wù)多實(shí)例部署的架構(gòu)圖

(1)用戶通過(guò)域名請(qǐng)求到DNS,由DNS解析域名后返回對(duì)應(yīng)的IP地址砚作,該IP及為Keepalived映射服務(wù)器的虛擬IP

(2)通過(guò)該虛擬IP訪問(wèn)到對(duì)應(yīng)的負(fù)載均衡器(Nginx)窘奏,這里Nginx部署兩個(gè),然后通過(guò)Keepalived來(lái)保證NG的高可用葫录,正常情況下由Keepalived-M將虛擬IP映射轉(zhuǎn)發(fā)至Nginx-M着裹,如果Nginx-M出現(xiàn)故障,此時(shí)Keepalived會(huì)切換至Keepalived-S開(kāi)始工作米同,從而保證了NG的單點(diǎn)故障問(wèn)題骇扇。

(3)通過(guò)Nginx負(fù)載均衡器摔竿,將請(qǐng)求路由到對(duì)應(yīng)的Tomcat服務(wù)。

3 搭建Keepalived + Nginx + Tomcat的高可用負(fù)載均衡架構(gòu)

3.1 需要準(zhǔn)備的軟件

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

(2)nginx-1.12.2.tar.gz

(3)keepalived-1.3.9.tar.gz

3.2 服務(wù)器準(zhǔn)備

兩臺(tái)服務(wù)器如:192.168.10.11少孝,192.168.10.12

3.3 安裝需要的依賴包

$ yum -yinstallgcc gcc-c++ automake pcre pcre-devel zlib zlib-developenopenssl-devel

3.4 安裝

3.4.1 安裝Tomcat

(1)分別在兩臺(tái)服務(wù)器中安裝Tomcat继低,解壓apache-tomcat-8.5.16.tar.gz及可完成安裝。

3.4.2 安裝Nginx

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

(2)進(jìn)入到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)進(jìn)入到keepalived-1.3.9目錄:cd keepalived-1.3.9

(3)執(zhí)行編譯:

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

b)sudo make && sudo make install

3.5 配置

3.5.1 分別配置兩臺(tái)服務(wù)器的Nginx

(1)分別修改兩臺(tái)服務(wù)器nginx配置文件稍走,vi /usr/local/nginx/conf/nginx.conf

(2)內(nèi)容如下:

#nginx進(jìn)程數(shù)worker_processes1;#單個(gè)進(jìn)程最大連接數(shù)events{worker_connections1024;}#http服務(wù)器配置http{includemime.types;default_typeapplication/octet-stream;sendfileon;#長(zhǎng)連接超時(shí)時(shí)間郁季,單位是秒keepalive_timeout65;#upstream負(fù)載均衡配置,配置路由到tomcat的服務(wù)地址以及權(quán)重upstreamlocalhost{server192.168.10.11:8080weight=2;server192.168.10.12:8080weight=2;? ? }#虛擬主機(jī)的配置server{#監(jiān)聽(tīng)端口listen80;#域名可以有多個(gè)钱磅,用空格隔開(kāi)server_namelocalhost;location/ {roothtml;indexindex.html index.htm;#nginx跟后端服務(wù)器連接超時(shí)時(shí)間(代理連接超時(shí))proxy_connect_timeout3;#后端服務(wù)器數(shù)據(jù)回傳時(shí)間(代理發(fā)送超時(shí))proxy_send_timeout30;#連接成功后梦裂,后端服務(wù)器響應(yīng)時(shí)間(代理接收超時(shí))proxy_read_timeout30;proxy_passhttp://localhost;? ? ? ? }error_page500502503504/50x.html;location=/50x.html {roothtml;? ? ? ? }? ? }}

3.5.2?主Keepalived配置

(1)修改11服務(wù)器的keepalived配置文件,vi /etc/keepalived/keepalived.conf

(2)內(nèi)容如下:

! Configuration Fileforkeepalived#全局配置global_defs {#keepalived切換的時(shí)候盖淡,發(fā)消息到指定的email年柠,可配置多個(gè)emailnotification_email {? ? feinik1@foxmail.com feinik2@foxmail.com? }#通知郵件從哪個(gè)地址發(fā)出notification_email_from feinik@foxmail.com#通知郵件的smtp地址smtp_server smtp.exmail.qq.com#連接smtp服務(wù)器的超時(shí)時(shí)間,單位秒smtp_connect_timeout30#Keepalived的機(jī)器標(biāo)識(shí)褪迟,一個(gè)網(wǎng)絡(luò)內(nèi)保持唯一router_id nginx-master}#執(zhí)行腳本配置vrrp_script chk_nginx {#腳本所在路徑script"/home/project/keepalived/check_nginx.sh"#腳本執(zhí)行間隔時(shí)間冗恨,秒interval2#優(yōu)先級(jí)weight2}#keepalived實(shí)例配置vrrp_instance VI_1 {#指定實(shí)例的初始狀態(tài),MASTER或BACKUP兩種狀態(tài)味赃,并且需要大寫stateMASTER#實(shí)例綁定的網(wǎng)卡interface ens33#虛擬路由標(biāo)識(shí)掀抹,是一個(gè)數(shù)字,整個(gè)VRRP內(nèi)唯一心俗,如果keepalived配置了主備傲武,需要相同virtual_router_id51#優(yōu)先級(jí),數(shù)值愈大城榛,優(yōu)先級(jí)越高priority100#MASTER與BACKUP之間同步檢查的時(shí)間間隔揪利,單位為秒advert_int1#通信驗(yàn)證authentication {? ? ? ? auth_type PASS? ? ? ? auth_pass feinik? ? }#追蹤外圍腳本track_script {#這里配置vrrp_script的名稱chk_nginx? ? }#虛擬ip配置,可配置多個(gè)virtual_ipaddress {192.168.10.200}}

3.5.3?備Keepalived配置

(1)修改12服務(wù)器的keepalived配置文件疟位,vi /etc/keepalived/keepalived.conf

(2)內(nèi)容如下:

! Configuration Fileforkeepalived#全局配置global_defs {#keepalived切換的時(shí)候喘垂,發(fā)消息到指定的email,可配置多個(gè)emailnotification_email {? ? feinik1@foxmail.com feinik2@foxmail.com? }#通知郵件從哪個(gè)地址發(fā)出notification_email_from feinik@foxmail.com#通知郵件的smtp地址smtp_server smtp.exmail.qq.com#連接smtp服務(wù)器的超時(shí)時(shí)間得院,單位秒smtp_connect_timeout30#Keepalived的機(jī)器標(biāo)識(shí)尿招,一個(gè)網(wǎng)絡(luò)內(nèi)保持唯一router_id nginx-master}#執(zhí)行腳本配置vrrp_script chk_nginx {#腳本所在路徑script"/home/project/keepalived/check_nginx.sh"#腳本執(zhí)行間隔時(shí)間阱驾,秒interval2#優(yōu)先級(jí)weight2}#keepalived實(shí)例配置vrrp_instance VI_1 {#指定實(shí)例的初始狀態(tài)里覆,MASTER或BACKUP兩種狀態(tài),并且需要大寫stateBACKUP#實(shí)例綁定的網(wǎng)卡interface ens33#虛擬路由標(biāo)識(shí)喧枷,是一個(gè)數(shù)字隧甚,整個(gè)VRRP內(nèi)唯一戚扳,如果keepalived配置了主備,需要相同virtual_router_id51#優(yōu)先級(jí)珠增,數(shù)值愈大砍艾,優(yōu)先級(jí)越高priority99#MASTER與BACKUP之間同步檢查的時(shí)間間隔脆荷,單位為秒advert_int1#通信驗(yàn)證authentication {? ? ? ? auth_type PASS? ? ? ? auth_pass feinik? ? }#追蹤外圍腳本track_script {#這里配置vrrp_script的名稱chk_nginx? ? }#虛擬ip配置,可配置多個(gè)virtual_ipaddress {192.168.10.200}}

3.5.4?Nginx狀態(tài)檢查腳本創(chuàng)建

(1)新建Nginx的狀態(tài)檢查腳本:check_nginx.sh

(2)內(nèi)容如下:

#!/bin/shNGINX=/usr/common/nginx/sbin/nginxPORT=80nmap localhost -p$PORT| grep"$PORT/tcp open"#echo $?if[ $?-ne0 ];then$NGINX-sstop#這里再次嘗試啟動(dòng)NG$NGINXsleep 5? ? nmap localhost -p$PORT| grep"$PORT/tcp open"[ $?-ne0 ] &&cd/usr/common/keepalived/sbin && pkill keepalivedecho"stoped"fi

4 運(yùn)行測(cè)試

(1)為了更直觀的查看到keepalived切換的效果苔严,將11服務(wù)器中的nginx的upstream服務(wù)只配置11的tomcat服務(wù)地址孤澎,12服務(wù)器中的upstream服務(wù)只配置12的tomcat服務(wù)地址覆旭,這樣只需要觀察將11服務(wù)器中的nginx關(guān)閉看使用虛擬ip是否可以訪問(wèn)到12服務(wù)器的tomcat型将。

(2)分別啟動(dòng)兩個(gè)服務(wù)器中的tomcat、nginx七兜、keepalived,訪問(wèn)虛擬ip:192.168.10.200铛碑,可以查看到訪問(wèn)的是主keepalived服務(wù)器的tomcat

(3)關(guān)閉11服務(wù)器的nginx汽烦,nginx -s stop撇吞,再次訪問(wèn)虛擬ip礁叔,如下:說(shuō)明主keepalived通過(guò)配置的腳本檢測(cè)到了本服務(wù)的nginx服務(wù)掛掉了琅关,所以立馬切換至了備的keepalived,這時(shí)12服務(wù)器的keepalived升為了主人乓,所以就訪問(wèn)到了12服務(wù)器的tomcat色罚。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末戳护,一起剝皮案震驚了整個(gè)濱河市腌且,隨后出現(xiàn)的幾起案子榛瓮,更是在濱河造成了極大的恐慌,老刑警劉巖禀晓,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件重付,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡确垫,警方通過(guò)查閱死者的電腦和手機(jī)删掀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門爬迟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)菊匿,“玉大人跌捆,你說(shuō)我怎么就攤上這事佩厚。” “怎么了潮瓶?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵毯辅,是天一觀的道長(zhǎng)思恐。 經(jīng)常有香客問(wèn)我膊毁,道長(zhǎng)婚温,這世上最難降的妖魔是什么栅螟? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任嵌巷,我火速辦了婚禮搪哪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘惑朦。我一直安慰自己漾月,他們只是感情好病梢,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著吩蔑,像睡著了一般。 火紅的嫁衣襯著肌膚如雪隧期。 梳的紋絲不亂的頭發(fā)上赘娄,一...
    開(kāi)封第一講書(shū)人閱讀 49,166評(píng)論 1 284
  • 那天性置,我揣著相機(jī)與錄音暑诸,去河邊找鬼个榕。 笑死西采,一個(gè)胖子當(dāng)著我的面吹牛凰萨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播械馆,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼胖眷,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了霹崎?” 一聲冷哼從身側(cè)響起珊搀,我...
    開(kāi)封第一講書(shū)人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎尾菇,沒(méi)想到半個(gè)月后境析,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體囚枪,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年劳淆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了链沼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片曲掰。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡底哥,死狀恐怖趾徽,靈堂內(nèi)的尸體忽然破棺而出蜡峰,到底是詐尸還是另有隱情,我是刑警寧澤崭庸,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站奠伪,受9級(jí)特大地震影響猜拾,放射性物質(zhì)發(fā)生泄漏肥惭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧称开,春花似錦扶镀、人聲如沸睛蛛。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瓦呼,已是汗流浹背蹋辅。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像目尖,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容