http://xxgblog.com/2015/05/17/nginx-start/php
本文主要介紹一些Nginx的最基本功能以及簡單配置,但不包括Nginx的安裝部署以及實現原理。廢話很少,直接開始。html
首先,Nginx是一個HTTP服務器,能夠將服務器上的靜態文件(如HTML、圖片)經過HTTP協議展示給客戶端。nginx
配置:後端
1 |
server { |
什麼是反向代理?緩存
客戶端原本能夠直接經過HTTP協議訪問某網站應用服務器,若是網站管理員在中間加上一個Nginx,客戶端請求Nginx,Nginx請求應用服務器,而後將結果返回給客戶端,此時Nginx就是反向代理服務器。
服務器
1 |
server { |
既然服務器能夠直接HTTP訪問,爲何要在中間加上一個反向代理,不是畫蛇添足嗎?反向代理有什麼做用?繼續往下看,下面的負載均衡、虛擬主機,都基於反向代理實現,固然反向代理的功能也不只僅是這些。併發
當網站訪問量很是大,網站站長開心賺錢的同時,也攤上事兒了。由於網站愈來愈慢,一臺服務器已經不夠用了。因而將相同的應用部署在多臺服務器上,將大量用戶的請求分配給多臺機器處理。同時帶來的好處是,其中一臺服務器萬一掛了,只要還有其餘服務器正常運行,就不會影響用戶使用。app
1 |
upstream myapp { |
的網站訪問量大,須要負載均衡。然而並非全部網站都如此出色,有的網站,因爲訪問量過小,須要節省成本,將多個網站部署在同一臺服務器上。框架
例如將www.aaa.com和www.bbb.com兩個網站部署在同一臺服務器上,兩個域名解析到同一個IP地址,可是用戶經過兩個域名卻能夠打開兩個徹底不一樣的網站,互相不影響,就像訪問兩個服務器同樣,因此叫兩個虛擬主機。
配置:
1 |
server { |
在服務器8080和8081分別開了一個應用,客戶端經過不一樣的域名訪問,根據server_name能夠反向代理到對應的應用服務器。
虛擬主機的原理是經過HTTP請求頭中的Host是否匹配server_name來實現的,有興趣的同窗能夠研究一下HTTP協議。
另外,server_name配置還能夠過濾有人惡意將某些域名指向你的主機服務器。
Nginx自己不支持PHP等語言,可是它能夠經過FastCGI來將請求扔給某些語言或框架處理(例如PHP、Python、Perl)。
1 |
server { |
配置中將.php結尾的請求經過FashCGI交給PHP-FPM處理,PHP-FPM是PHP的一個FastCGI管理器。有關FashCGI能夠查閱其餘資料,本文再也不介紹。
fastcgi_pass和proxy_pass有什麼區別?下面一張圖帶你看明白:
1.處理靜態文件,索引文件以及自動索引;
2.反向代理加速(無緩存),簡單的負載均衡和容錯;
3.FastCGI,簡單的負載均衡和容錯;
4.模塊化的結構。過濾器包括gzipping,byte ranges,chunked responses,以及 SSI-filter。在SSI過濾器中,到同一個 proxy 或者 FastCGI 的多個子請求併發處理;
5.SSL 和 TLS SNI 支持;
6.IMAP/POP3代理服務功能:
7.使用外部 HTTP 認證服務器重定向用戶到 IMAP/POP3 後端;
8.使用外部 HTTP 認證服務器認證用戶後鏈接重定向到內部的 SMTP 後端;
以上nginx的基礎功能。