nginx 能做的事

nginix.jpg

Nginx主要功能:

1癣疟、反向代理
2挣柬、負(fù)載均衡
3、HTTP服務(wù)器(包含動(dòng)靜分離)
4睛挚、正向代理


一邪蛔、反向代理

反向代理應(yīng)該是 Nginx 做的最多的一件事了,什么是反向代理呢扎狱,以下是百度百科的說法:反向代理(Reverse Proxy)方式是指以代理服務(wù)器來接受 internet上 的連接請求侧到,然后將請求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器,并將從服務(wù)器上得到的結(jié)果返回給 internet 上請求連接的客戶端淤击,此時(shí)代理服務(wù)器對外就表現(xiàn)為一個(gè)反向代理服務(wù)器匠抗。簡單來說就是真實(shí)的服務(wù)器不能直接被外部網(wǎng)絡(luò)訪問,所以需要一臺代理服務(wù)器污抬,而代理服務(wù)器能被外部網(wǎng)絡(luò)訪問的同時(shí)又跟真實(shí)服務(wù)器在同一個(gè)網(wǎng)絡(luò)環(huán)境汞贸,當(dāng)然也可能是同一臺服務(wù)器,端口不同而已印机。 下面貼上一段簡單的實(shí)現(xiàn)反向代理的代碼

server {  
      listen      80;                                                        
      server_name  localhost;                                              
      client_max_body_size 1024M;

      location / {
          proxy_pass http://localhost:8080;
          proxy_set_header Host $host:$server_port;
      }
  } 

保存配置文件后啟動(dòng) Nginx著蛙,這樣當(dāng)我們訪問 localhost 的時(shí)候,就相當(dāng)于訪問 localhost:8080 了耳贬。


二、負(fù)載均衡

負(fù)載均衡也是 Nginx 常用的一個(gè)功能猎唁,負(fù)載均衡其意思就是分?jǐn)偟蕉鄠€(gè)操作單元上進(jìn)行執(zhí)行咒劲,例如:Web服務(wù)器、FTP服務(wù)器诫隅、企業(yè)關(guān)鍵應(yīng)用服務(wù)器和其它關(guān)鍵任務(wù)服務(wù)器等腐魂,從而共同完成工作任務(wù)。簡單而言就是當(dāng)有2臺或以上服務(wù)器時(shí)逐纬,根據(jù)規(guī)則隨機(jī)的將請求分發(fā)到指定的服務(wù)器上處理蛔屹,負(fù)載均衡配置一般都需要同時(shí)配置反向代理,通過反向代理跳轉(zhuǎn)到負(fù)載均衡豁生。而Nginx目前支持自帶3種負(fù)載均衡策略兔毒,還有2種常用的第三方策略漫贞。
1、RR(默認(rèn))

每個(gè)請求按時(shí)間順序逐一分配到不同的后端服務(wù)器育叁,如果后端服務(wù)器down掉迅脐,能自動(dòng)剔除。
簡單配置
  upstream test {
      server localhost:8080;
      server localhost:8081;
  }
  server {
      listen      81;                                                        
      server_name  localhost;                                              
      client_max_body_size 1024M;

      location / {
          proxy_pass http://test;
          proxy_set_header Host $host:$server_port;
      }
  } 

配置了2臺服務(wù)器豪嗽,當(dāng)然實(shí)際上是一臺谴蔑,只是端口不一樣而已,而8081的服務(wù)器是不存在的,也就是說訪問不到龟梦,但是我們訪問 http://localhost 的時(shí)候,也不會有問題隐锭,會默認(rèn)跳轉(zhuǎn)到http://localhost:8080 具體是因?yàn)镹ginx會自動(dòng)判斷服務(wù)器的狀態(tài),如果服務(wù)器處于不能訪問(服務(wù)器掛了)计贰,就不會跳轉(zhuǎn)到這臺服務(wù)器钦睡,所以也避免了一臺服務(wù)器掛了影響使用的情況,由于 Nginx 默認(rèn)是RR策略蹦玫,所以我們不需要其他更多的設(shè)置赎婚。

2、權(quán)重
指定輪詢幾率樱溉,weight和訪問比率成正比挣输,用于后端服務(wù)器性能不均的情況。 例如

upstream test {
     server localhost:8080 weight=9;
     server localhost:8081 weight=1;
 }

那么10次一般只會有1次會訪問到8081福贞,而有9次會訪問到8080撩嚼。

3、ip_hash
上面的2種方式都有一個(gè)問題挖帘,那就是下一個(gè)請求來的時(shí)候請求可能分發(fā)到另外一個(gè)服務(wù)器完丽,當(dāng)我們的程序不是無狀態(tài)的時(shí)候(采用了session保存數(shù)據(jù)),這時(shí)候就有一個(gè)很大的很問題了拇舀,比如把登錄信息保存到了session中逻族,那么跳轉(zhuǎn)到另外一臺服務(wù)器的時(shí)候就需要重新登錄了,所以很多時(shí)候我們需要一個(gè)客戶只訪問一個(gè)服務(wù)器骄崩,那么就需要用iphash了聘鳞,iphash的每個(gè)請求按訪問ip的hash結(jié)果分配,這樣每個(gè)訪客固定訪問一個(gè)后端服務(wù)器要拂,可以解決session的問題抠璃。

upstream test {
     ip_hash;
     server localhost:8080;
     server localhost:8081;
 }

4、fair(第三方)
按后端服務(wù)器的響應(yīng)時(shí)間來分配請求脱惰,響應(yīng)時(shí)間短的優(yōu)先分配搏嗡。

upstream backend { 
    fair; 
    server localhost:8080;
    server localhost:8081;
} 

5、url_hash(第三方)
按訪問url的hash結(jié)果來分配請求,使每個(gè)url定向到同一個(gè)后端服務(wù)器采盒,后端服務(wù)器為緩存時(shí)比較有效旧乞。 在upstream中加入hash語句,server語句中不能寫入weight等其他的參數(shù)纽甘,hash_method是使用的hash算法良蛮。

upstream backend { 
    hash $request_uri; 
    hash_method crc32; 
    server localhost:8080;
    server localhost:8081;
} 

以上5種負(fù)載均衡各自適用不同情況下使用,所以可以根據(jù)實(shí)際情況選擇使用哪種策略模式,不過fair和url_hash需要安裝第三方模塊才能使用悍赢,由于本文主要介紹Nginx能做的事情决瞳,所以Nginx安裝第三方模塊不會再本文介紹。


三左权、HTTP服務(wù)器

Nginx本身也是一個(gè)靜態(tài)資源的服務(wù)器皮胡,當(dāng)只有靜態(tài)資源的時(shí)候,就可以使用Nginx來做服務(wù)器赏迟,同時(shí)現(xiàn)在也很流行動(dòng)靜分離屡贺,就可以通過Nginx來實(shí)現(xiàn),首先看看Nginx做靜態(tài)資源服務(wù)器锌杀。

  server {
      listen      80;                                                        
      server_name  localhost;                                              
      client_max_body_size 1024M;

      location / {
              root  e:\wwwroot;
              index  index.html;
          }
  } 

這樣如果訪問http://localhost 就會默認(rèn)訪問到E盤wwwroot目錄下面的index.html甩栈,如果一個(gè)網(wǎng)站只是靜態(tài)頁面的話,那么就可以通過這種方式來實(shí)現(xiàn)部署糕再。

動(dòng)靜分離
動(dòng)靜分離是讓動(dòng)態(tài)網(wǎng)站里的動(dòng)態(tài)網(wǎng)頁根據(jù)一定規(guī)則把不變的資源和經(jīng)常變的資源區(qū)分開來量没,動(dòng)靜資源做好了拆分以后,我們就可以根據(jù)靜態(tài)資源的特點(diǎn)將其做緩存操作突想,這就是網(wǎng)站靜態(tài)化處理的核心思路殴蹄。

upstream test{  
      server localhost:8080;  
      server localhost:8081;  
  } 

  server {  
      listen      80;  
      server_name  localhost; 

      location / {  
          root  e:\wwwroot;  
          index  index.html;  
      } 

      # 所有靜態(tài)請求都由nginx處理,存放目錄為html  
      location ~ \.(gif|jpg|jpeg|png|bmp|swf|css|js)$ {  
          root    e:\wwwroot;  
      } 

      # 所有動(dòng)態(tài)請求都轉(zhuǎn)發(fā)給tomcat處理  
      location ~ \.(jsp|do)$ {  
          proxy_pass  http://test; 
      } 

      error_page  500 502 503 504  /50x.html;  
      location = /50x.html {  
          root  e:\wwwroot;  
      }  
  }  

這樣我們就可以把HTML以及圖片和css以及js放到wwwroot目錄下猾担,而tomcat只負(fù)責(zé)處理jsp和請求袭灯,
例如當(dāng)我們后綴為gif的時(shí)候,Nginx默認(rèn)會從wwwroot獲取到當(dāng)前請求的動(dòng)態(tài)圖文件返回绑嘹,當(dāng)然這里的靜態(tài)文件跟Nginx是同一臺服務(wù)器稽荧,我們也可以在另外一臺服務(wù)器,然后通過反向代理和負(fù)載均衡配置過去就好了工腋,只要搞清楚了最基本的流程姨丈,很多配置就很簡單了,另外localtion后面其實(shí)是一個(gè)正則表達(dá)式夷蚊,所以非常靈活。


四髓介、正向代理

正向代理惕鼓,意思是一個(gè)位于客戶端和原始服務(wù)器(origin server)之間的服務(wù)器,為了從原始服務(wù)器取得內(nèi)容唐础,客戶端向代理發(fā)送一個(gè)請求并指定目標(biāo)(原始服務(wù)器)箱歧,然后代理向原始服務(wù)器轉(zhuǎn)交請求并將獲得的內(nèi)容返回給客戶端矾飞。客戶端才能使用正向代理呀邢。當(dāng)你需要把你的服務(wù)器作為代理服務(wù)器的時(shí)候洒沦,可以用Nginx來實(shí)現(xiàn)正向代理,但是目前Nginx有一個(gè)問題价淌,那么就是不支持HTTPS申眼,雖然我百度到過配置HTTPS的正向代理,但是到最后發(fā)現(xiàn)還是代理不了蝉衣,當(dāng)然可能是我配置的不對括尸。

  resolver 114.114.114.114 8.8.8.8;
  server {

      resolver_timeout 5s;

      listen 81;

      access_log  e:\wwwroot\proxy.access.log;
      error_log  e:\wwwroot\proxy.error.log;

      location / {
          proxy_pass http://$host$request_uri;
      }
  } 

resolver是配置正向代理的DNS服務(wù)器,listen 是正向代理的端口病毡,配置好了就可以在ie上面或者其他代理插件上面使用服務(wù)器ip+端口號進(jìn)行代理了濒翻。

注意:Nginx是支持熱啟動(dòng)的,也就是說當(dāng)我們修改配置文件后啦膜,不用關(guān)閉Nginx有送,就可以實(shí)現(xiàn)讓配置生效。Nginx從新讀取配置的命令是:nginx -s reload 僧家。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末雀摘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子啸臀,更是在濱河造成了極大的恐慌届宠,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乘粒,死亡現(xiàn)場離奇詭異豌注,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)灯萍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進(jìn)店門轧铁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人旦棉,你說我怎么就攤上這事齿风。” “怎么了绑洛?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵救斑,是天一觀的道長。 經(jīng)常有香客問我真屯,道長脸候,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮运沦,結(jié)果婚禮上泵额,老公的妹妹穿的比我還像新娘。我一直安慰自己携添,他們只是感情好嫁盲,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著烈掠,像睡著了一般羞秤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上向叉,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天锥腻,我揣著相機(jī)與錄音,去河邊找鬼母谎。 笑死瘦黑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的奇唤。 我是一名探鬼主播幸斥,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼咬扇!你這毒婦竟也來了甲葬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤懈贺,失蹤者是張志新(化名)和其女友劉穎经窖,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體梭灿,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡画侣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了堡妒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片配乱。...
    茶點(diǎn)故事閱讀 39,711評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖皮迟,靈堂內(nèi)的尸體忽然破棺而出搬泥,到底是詐尸還是另有隱情,我是刑警寧澤伏尼,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布忿檩,位于F島的核電站,受9級特大地震影響爆阶,放射性物質(zhì)發(fā)生泄漏燥透。R本人自食惡果不足惜代赁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望兽掰。 院中可真熱鬧,春花似錦徒役、人聲如沸孽尽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杉女。三九已至,卻和暖如春鸳吸,著一層夾襖步出監(jiān)牢的瞬間熏挎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工晌砾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坎拐,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓养匈,卻偏偏與公主長得像哼勇,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子呕乎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評論 2 353

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

  • nginx概述 nginx是一款自由的积担、開源的、高性能的HTTP服務(wù)器和反向代理服務(wù)器猬仁;同時(shí)也是一個(gè)IMAP帝璧、PO...
    逝者如斯灬閱讀 3,417評論 0 16
  • 參考:https://www.cnblogs.com/zhouxinfei/p/7862285.html 侵刪 n...
    會飛的魚_500閱讀 1,226評論 0 1
  • 《老男孩Linux運(yùn)維》Nginx Documentation 集群簡介 集群就是指一組(若干)相互獨(dú)立的計(jì)算機(jī),...
    Zhang21閱讀 3,395評論 0 51
  • 當(dāng)前大多數(shù)的互聯(lián)網(wǎng)系統(tǒng)都使用了服務(wù)器集群技術(shù)买雾,集群是將相同服務(wù)部署在多臺服務(wù)器上構(gòu)成一個(gè)集群整體對外提供服務(wù)把曼,這些...
    jiangmo閱讀 12,873評論 3 36
  • 大家晚上好呀~今天我們一起來看看《鼻子》的結(jié)局吧~ 一天晚上,大概是日暮之后驟然起了風(fēng)漓穿,塔上風(fēng)鈴的嘈音傳到枕邊來嗤军。...
    共書君閱讀 268評論 0 0