您好,登錄后才能下訂單哦!
Nginx 是一個高性能的 HTTP 和反向代理服務器,以高穩定性、豐富的功能集、示例配置文件和低系統資源的消耗而聞名。
Nginx 特點 處理靜態文件,索引文件以及自動索引;打開文件描述符緩沖. 無緩存的反向代理加速,簡單的負載均衡和容錯. FastCGI,簡單的負載均衡和容錯. 模塊化的結構。包括 gzipping, byte ranges, chunked responses,以及 SSI-filter 等 filter。如果由 FastCGI 或其它代理服務器處理單頁中存在的多個 SSI,則這項處理可以并行運行,而不需要相互等待。 支持 SSL 和 TLSSNI. 主要應用場合 1、靜態 HTTP 服務器
首先,Nginx是一個 HTTP 服務器,可以將服務器上的靜態文件(如 HTML、圖片)通過 HTTP 協議展現給客戶端。
配置:
server { listen 80; # 端口號 location / { root /usr/share/nginx/html; # 靜態文件路徑 } }
2、反向代理服務器
什么是反向代理?
客戶端本來可以直接通過 HTTP 協議訪問某網站應用服務器,如果網站管理員在中間加上一個 Nginx,客戶端請求Nginx,Nginx 請求應用服務器,然后將結果返回給客戶端,此時 Nginx 就是反向代理服務器。
配置:
server { listen 80; location / { proxy_pass http://192.168.20.1:8080; # 應用服務器HTTP地址 } }
既然服務器可以直接 HTTP 訪問,為什么要在中間加上一個反向代理,不是多此一舉嗎?反向代理有什么作用?繼續往下看,下面的負載均衡、虛擬主機,都基于反向代理實現,當然反向代理的功能也不僅僅是這些。
3、負載均衡
當網站訪問量非常大,網站站長開心賺錢的同時,也攤上事兒了。因為網站越來越慢,一臺服務器已經不夠用了。于是將相同的應用部署在多臺服務器上,將大量用戶的請求分配給多臺機器處理。同時帶來的好處是,其中一臺服務器萬一掛了,只要還有其他服務器正常運行,就不會影響用戶使用。
當我們網站進行大的升級更新時,我們不可能直接將所有的服務器都關掉,然后再升級的。通常我們都是批量的關掉一些服務器,去升級網站,當有用戶的請求時則分配給其他還在運作的機器處理。當之前關掉的機器更新完成后,再次開啟,然后又批量關掉部分機器,如上循環,直到最后全部機器都更新完成。這樣就不會影響用戶使用。
Nginx 可以通過反向代理來實現負載均衡。
配置:
upstream myapp { server 192.168.20.1:8080; # 應用服務器1 server 192.168.20.2:8080; # 應用服務器2 } server { listen 80; location / { proxy_pass http://myapp; } }
4、虛擬主機
網站訪問量大,需要負載均衡。然而并不是所有網站都如此出色,有的網站,由于訪問量太小,需要節省成本,將多個網站部署在同一臺服務器上。
例如將 www.aaa.com 和 www.bbb.com 兩個網站部署在同一臺服務器上,兩個域名解析到同一個 IP 地址,但是用戶通過兩個域名卻可以打開兩個完全不同的網站,互相不影響,就像訪問兩個服務器一樣,所以叫兩個虛擬主機。
配置:
server { listen 80 default_server; server_name _; return 444; # 過濾其他域名的請求,返回444狀態碼 } server { listen 80; server_name www.aaa.com; # www.aaa.com域名 location / { proxy_pass http://localhost:8080; # 對應端口號8080 } } server { listen 80; server_name www.bbb.com; # www.bbb.com域名 location / { proxy_pass http://localhost:8081; # 對應端口號8081 } }
在服務器 8080 和 8081 兩個端口分別開了一個應用,客戶端通過不同的域名訪問,根據 server_name 可以反向代理到對應的應用服務器。
虛擬主機的原理是通過 HTTP 請求頭中的 Host 是否匹配 server_name 來實現的,有興趣的同學可以研究一下 HTTP 協議。
另外,server_name 配置還可以過濾有人惡意將某些域名指向你的主機服務器。
5、FastCGI
Nginx 本身不支持 PHP 等語言,但是它可以通過 FastCGI 來將請求扔給某些語言或框架處理(例如 PHP、Python、Perl)。
server { listen 80; location ~ \.php$ { include fastcgi_params; fastcgi_param SCRIPT_FILENAME /PHP文件路徑$fastcgi_script_name; # PHP文件路徑 fastcgi_pass 127.0.0.1:9000; # PHP-FPM地址和端口號 # 另一種方式:fastcgi_pass unix:/var/run/php5-fpm.sock; } }
配置中將 .php 結尾的請求通過 FashCGI 交給 PHP-FPM 處理,PHP-FPM 是 PHP 的一個 FastCGI 管理器。有關FashCGI 可以查閱其他資料,本文不再介紹。
fastcgi_pass 和 proxy_pass 有什么區別?下面一張圖帶你看明白:
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。