nginx tomcat部署方案

一個相對完整的服務部署方案至少應該考慮以下幾方面問題:

橫向擴展能力

合理的負載分配策略

服務節點異常的處理

傳統的服務器主從結構因為在橫向擴展能力上的局限性,現已不再采用。目前推薦的的集群部署均采用Nginx做為前端服務器+負載均衡器的方式。


?一、部署結構


Nginx 做為前端服務器,可以起到以下主要作用:

??????1) 靜態資源請求分流

?????????????由于Nginx對于靜態資源的處理速度遠遠大于tomcat, weblogic等主流應用服務器,把所有靜態資源請求讓Nginx進行處理可以在很大程度上減輕后端服務器的壓力,從而將后端服務器處理資源盡可能的用于需要計算的請求,進而加快相應速度。

???????2)基于策略的負載均衡

?????????????Nginx可以靈活的跟據實際場景設置負載分發方式,即便后端服務器資源不平衡,也可以根據根據策略為不同集群后端實例施加不相等,但是合理的負載。

??????3)抗并發

Nginx采用異步非阻塞處理模型(epoll),在占用內存極低的情況下,默認配置就可支持15000并發請求,在經過適當優化的情況下 (非nginx 集群),甚至能夠處理超過50000并發請求。(單個tomcat在處理超過300并發請求的情況下就會出現明顯延遲)。

?注:Nginx epoll模型實現不支持windows平臺

????????4)為熱部署/滾動部署提供可能性

?????????????Nginx本身支持熱部署,改動配置只需刷新就能生效,這樣可以非常容易的實現熱部署。

想了解更多關于Nginx? 點這里

二、需要注意的問題

??????1)Session

?????????????如果簡單的按照策略分發請求,而不對session做分布式處理的話,就會出現session在某個集群節點上找不到的情況。舉個例子:

?????????????集群有2個節點 N1和N2, 如果分發策略是承擔50%的負載,具體請求隨機分發, 那么就會出現用戶登陸請求由N1處理,對應session由N1創建,N1保管, 那么當后續請求被派發到N2的時候,N2就會出現找不到session的情況,報session time out.

?????????????目前對于此問題有兩種解決方案:

- 粘性session

???????????????粘性session要求Nginx將來自于同一客戶端的請求分發到同一個集群實例,這樣可以大大簡化應用程序對于集群部署環境進行特殊實現的難度。(不需要分布式處理session和緩存)。 但是這樣的方案在需要熱部署或者對于集群容錯性要求很高的場景下,并不能滿足需要。

- 分布式sesssion

????????????????分布式session使用高性能的內存存儲服務,如:Redus, Memcache,集中化的存儲session數據,集群實例總是從session存儲服務中取得session數據,這樣可以避免無法找到session的情況。 此方案需要修改session存儲實現,并且因為網間訪問在效率上相比內存直接存取有數量級的差別,所以會造成一定的效率下降,并且,集中化session存儲會帶來單點失敗的問題,將session存儲集群化可以解決,但明顯加大了部署的復雜性。

???目前框架只支持粘性session的解決方案,如果特定項目對服務的不間斷性和容錯性有很高的要求,可以聯系研發部提供分布式session的解決方案。

??????2) 特定資源集中化管理

????????????對于需要在集群實例間共享訪問的資源 (如用戶上傳的圖片,文件),必須集中化管理,否則會出現資源無法找到的錯誤


??????3) Data Base 負載能力瓶頸

????????????在使用以上部署架構以后,因為應用服務的橫向擴展能力大大增強(增加集群實例個數會立即提高集群處理能力), DB服務器的處理能力需要被密切關注,否則很容易成為整個集群性能最大的瓶頸。 通常來說,增加硬件,或者集群化DB是首先想到的最快速的解決方案。


三、部署詳細步驟

???????1. 部署DB? (省略)

???????2. 創建文件共享目錄 (省略)

???????3. 部署應用服務 (省略)

???????4. 部署Nginx

1) 下載Nginx?1.14.0?(穩定版)

??????????????2)安裝

?????????????????[root@localhost local]# pwd??????????? //顯示nginx壓縮包所在路徑

??????????????????/usr/local

??????????????????[root@localhost local]# ls????????? //查看壓縮包

? ? ? ? ? ? ? ? ? nginx-1.14.0.tar.gz?

?????????????????[root@localhost local]# tar -zxvf nginx-1.14.0.tar.gz?? //解壓

?????????????????[root@localhost nginx-1.14.0]# make && make install?? //進入到nginx解壓文件中執行該命令,進行編譯、安裝。

?????????????????[root@localhost nginx]# cd sbin/???????????????? //進入到sbin目錄

? ? ? ? ? ? ? ? [root@localhost sbin]# ./nginx? ? ? ? ? ? ? ? ? //啟動nginx



?????????????????

???????5. 測試

訪問站點


??????????????從瀏覽器訪問我們配置的站點ip:

?

???6. 配置nginx.conf

???????[root@localhost /]# vim /usr/local/nginx/conf/nginx.conf ????????????????//編輯配置文件


#設定http服務器,利用它的反向代理功能提供負載均衡支持

http {

#設定mime類型,類型由mime.type文件定義

include?????? /etc/nginx/mime.types;

default_type? application/octet-stream;

#設定日志格式

access_log??? /var/log/nginx/access.log;

#開啟gzip壓縮

gzip? on;

gzip_disable "MSIE [1-6]\.(?!.*SV1)";

????#設定負載均衡的服務器列表

upstream webapp {

#weigth參數表示權值,權值越高被分配到的幾率越大

server? 192.168.0.112:8081 weight=4;

server? 192.168.0.129:8082 weight=3;

server? 192.168.0.130:8083 weight=3;

ip_hash;?? #粘性session

}

#第一個虛擬服務器

server {

#偵聽192.168.8.x的80端口

listen?????? 80;

server_name? 192.168.8.x;

location / {

proxy_pass http://webapp;???????????? #請求轉向mysvr 定義的服務器列表

proxy_next_upstream http_502 http_504 error timeout invalid_header;??? #錯誤界面

proxy_set_header Host $host;????????? ????#后端的Web服務器可以通過X-Forwarded-For獲取用戶真實IP

proxy_set_header X-Forwarded-For $remote_addr;

}

}

}??

???7. 特定資源集中化管理

?????????????1) 創建資源目錄

??????????????[root@localhost /]# mkdir? /usr/webserver/static/ROOT/ ??????????????//創建資源目錄

??2)配置資源請求

?????????????[root@localhost /]# vim /usr/local/nginx/conf/nginx.conf ????????????????//編輯配置文件

???????????????location /images/ {????????????????????????????????? //配置所有請求為../images的默認請求到/usr/webserver/static/ROOT/WEB-INF/目錄

??????????????????????????????????????alias?? ??/usr/webserver/static/ROOT/WEB-INF/;????????

??????????????????????????????????????autoindex on;

????????????????}

?????????????location /css/ {??????????????? ????????????//配置所有請求為../css的默認請求到 /usr/webserver/static/ROOT/WEB-INF/css/目錄

????????????????????????????????alias? /usr/webserver/static/ROOT/WEB-INF/css/;

??????????????????????????????autoindex on;

????????}


四、配置文件詳解

?1. 粘性會話和負載均衡配置

????????在多臺后臺服務器的環境下,我們為了確保一個客戶只和一臺服務器通信,我們勢必使用長連接。使用什么方式來實現這種連接?? 呢,常見的有使用nginx自帶的ip_hash和jvm_route兩種方式來進行配置。

?????1)ip_hash

???????????nginx中的ip_hash技術能夠將某個ip的請求定向到同一臺后端,這樣一來這個ip下的某個客戶端和某個后端就能建立起穩固的? session,ip_hash是在upstream配置中定義的:?

upstream backend {

server 192.168.12.10:8080 ;

server 192.168.12.11:9090 ;

ip_hash;

}

2) nginx_upstream_jvm_route

1/ nginx_upstream_jvm_route安裝

下載地址(svn):http://nginx-upstream-jvm-route.googlecode.com/svn/trunk/

假設nginx_upstream_jvm_route下載后的路徑為/usr/local/nginx_upstream_jvm_route,

(1)進入nginx源碼路徑

patch -p0 < /usr/local/nginx_upstream_jvm_route/jvm_route.patch

(2)./configure? --with-http_stub_status_module --with-http_ssl_module --prefix=/usr/local/nginx --with-pcre=/usr/local/pcre-8.33 --add-module=/usr/local/nginx_upstream_jvm_route

(3)make & make install

2/ nginx配置

upstream? tomcats_jvm_route

{

# ip_hash;

server?? 192.168.33.10:8090 srun_id=tomcat01;

server?? 192.168.33.11:8090 srun_id=tomcat02;

jvm_route $cookie_JSESSIONID|sessionid reverse;

}

?3/ tomcat配置

修改192.168.33.10:8090tomcat的server.xml,

將?

<Engine name="Catalina" defaultHost="localhost" >?

修改為:

<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat01">?

?同理,在192.168.33.11:8090server.xml中增加jvmRoute="tomcat02"。

?2. nginx.conf詳解

#運行用戶

user www-data;

#啟動進程,通常設置成和cpu的數量相等

worker_processes? 1;

#全局錯誤日志及PID文件

error_log? /var/log/nginx/error.log;

pid??????? /var/run/nginx.pid;

#工作模式及連接數上限

events {

use?? epoll;???????????? #epoll是多路復用IO(I/O Multiplexing)中的一種方式,但是僅用于linux2.6以上內核,可以大大提高nginx的性能

worker_connections? 1024;#單個后臺worker process進程的最大并發鏈接數

# multi_accept on;

}

#設定http服務器,利用它的反向代理功能提供負載均衡支持

http {

#設定mime類型,類型由mime.type文件定義

include?????? /etc/nginx/mime.types;

default_type? application/octet-stream;

#設定日志格式

access_log??? /var/log/nginx/access.log;

#sendfile 指令指定 nginx 是否調用 sendfile 函數(zero copy 方式)來輸出文件,對于普通應用,

#必須設為 on,如果用來進行下載等應用磁盤IO重負載應用,可設置為 off,以平衡磁盤與網絡I/O處理速度,降低系統的uptime.

sendfile??????? on;

#tcp_nopush???? on;

#連接超時時間

#keepalive_timeout? 0;

keepalive_timeout? 65;

tcp_nodelay??????? on;

#開啟gzip壓縮

gzip? on;

gzip_disable "MSIE [1-6]\.(?!.*SV1)";

#設定請求緩沖

client_header_buffer_size??? 1k;

large_client_header_buffers? 4 4k;

include /etc/nginx/conf.d/*.conf;

include /etc/nginx/sites-enabled/*;

#設定負載均衡的服務器列表

upstream mysvr {

#weigth參數表示權值,權值越高被分配到的幾率越大

#本機上的Squid開啟3128端口

server 192.168.8.1:3128 weight=5;

server 192.168.8.2:80? weight=1;

server 192.168.8.3:80? weight=6;

}

server {

#偵聽80端口

listen?????? 80;

#定義使用www.xx.com訪問

server_name? www.xx.com;

#設定本虛擬主機的訪問日志

access_log? logs/www.xx.com.access.log? main;

#默認請求

location / {

root?? /root;????? #定義服務器的默認網站根目錄位置

index index.php index.html index.htm;?? #定義首頁索引文件的名稱

fastcgi_pass? www.xx.com;

fastcgi_param? SCRIPT_FILENAME? $document_root/$fastcgi_script_name;

include /etc/nginx/fastcgi_params;

}

# 定義錯誤提示頁面

error_page?? 500 502 503 504 /50x.html;

location = /50x.html {

root?? /root;

}

#靜態文件,nginx自己處理

location ~ ^/(images|javascript|js|css|flash|media|static)/ {

root /var/www/virtual/htdocs;

#過期30天,靜態文件不怎么更新,過期可以設大一點,如果頻繁更新,則可以設置得小一點。

expires 30d;

}

#PHP 腳本請求全部轉發到 FastCGI處理. 使用FastCGI默認配置.

location ~ \.php$ {

root /root;

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

fastcgi_param SCRIPT_FILENAME /home/www/www$fastcgi_script_name;

include fastcgi_params;

}

#設定查看Nginx狀態的地址

location /NginxStatus {

stub_status??????????? on;

access_log????????????? on;

auth_basic????????????? "NginxStatus";

auth_basic_user_file? conf/htpasswd;

}

#禁止訪問 .htxxx 文件

location ~ /\.ht {

deny all;

}

}

}

?4. 靜態資源配置

????????配置靜態資源服務器的話,就是把一部分請求分離出來,讓這些請求直接訪問到服務器的磁盤目錄中。

例如配置如下:

指定路徑對應的目錄。location可以使用正則表達式匹配。并指定對應的硬盤中的目錄。如下:

??location /images/ {

????????????root?? ?/working/static/ROOT/WEB-INF/;

????????????autoindex on;

????????}

location /images/ {

????????????alias? /working/static/ROOT/WEB-INF/images/;

????????????autoindex on;

????????}

這個配置表示輸入 localhost:80/images/wrong.png時會訪問本機的/working/static/ROOT/WEB-INF/images/wrong.png; 目錄。

root和alias 詳解

當訪問http://localhost/images/wrong.png時,root是去/working/static/ROOT/WEB-INF/image/wrong.png請求文件,alias是去/working/static/ROOT/WEB-INF/images/wrong.png請求,也就是說

root響應的路徑:配置的路徑+完整訪問路徑(完整的location配置路徑+靜態文件)

alias響應的路徑:配置路徑+靜態文件(去除location中配置的路徑)

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,527評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,687評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,640評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,957評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,682評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,011評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,009評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,183評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,714評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,435評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,665評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,148評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,838評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,251評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,588評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,379評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,627評論 2 380

推薦閱讀更多精彩內容