Nginx是一款輕量級服務(wù)器/反向代理服務(wù)器及電子郵件代理服務(wù)器,在BSD-like 協(xié)議下發(fā)行。其特點是占有內(nèi)存少,并發(fā)能力強。
1、靜態(tài)HTTP服務(wù)器
首先,Nginx是一個HTTP服務(wù)器,可以將服務(wù)器上的靜態(tài)文件(如HTML、圖片)通過HTTP協(xié)議展現(xiàn)給客戶端。
配置:
server {
listen 80; # 端口號
location / {
root /usr/share/nginx/html; # 靜態(tài)文件路徑
}
}
2、反向代理服務(wù)器
客戶端本來可以直接通過HTTP協(xié)議訪問某網(wǎng)站應(yīng)用服務(wù)器,如果網(wǎng)站管理員在中間加上一個Nginx,客戶端請求Nginx,Nginx請求應(yīng)用服務(wù)器,然后將結(jié)果返回給客戶端,此時Nginx就是反向代理服務(wù)器。
反向代理

配置:
server {
listen 80;
location / {
proxy_pass http://192.168.0.112:8080; # 應(yīng)用服務(wù)器HTTP地址
}
}
既然服務(wù)器可以直接HTTP訪問,為什么要在中間加上一個反向代理,不是多此一舉嗎?反向代理有什么作用?繼續(xù)往下看,下面的負(fù)載均衡、虛擬主機,都基于反向代理實現(xiàn),當(dāng)然反向代理的功能也不僅僅是這些。
3、負(fù)載均衡
當(dāng)網(wǎng)站訪問量非常大,也攤上事兒了。因為網(wǎng)站越來越慢,一臺服務(wù)器已經(jīng)不夠用了。于是將相同的應(yīng)用部署在多臺服務(wù)器上,將大量用戶的請求分配給多臺機器處理。同時帶來的好處是,其中一臺服務(wù)器萬一掛了,只要還有其他服務(wù)器正常運行,就不會影響用戶使用。
Nginx可以通過反向代理來實現(xiàn)負(fù)載均衡。

負(fù)載均衡
配置:
upstream myapp {
server 192.168.0.111:8080; # 應(yīng)用服務(wù)器1
server 192.168.0.112:8080; # 應(yīng)用服務(wù)器2
}
server {
listen 80;
location / {
proxy_pass http://myweb;
}
}
4、虛擬主機
當(dāng)網(wǎng)站訪問量大,需要負(fù)載均衡。然而并不是所有網(wǎng)站都如此出色,有的網(wǎng)站,由于訪問量太小,需要節(jié)省成本,將多個網(wǎng)站部署在同一臺服務(wù)器上。
例如將www.a.com和www.b.com兩個網(wǎng)站部署在同一臺服務(wù)器上,兩個域名解析到同一個IP地址,但是用戶通過兩個域名卻可以打開兩個完全不同的網(wǎng)站,互相不影響,就像訪問兩個服務(wù)器一樣,所以叫兩個虛擬主機。
配置:
server {
listen 80 default_server;
server_name _;
return 444; # 過濾其他域名的請求,返回444狀態(tài)碼
}
server {
listen 80;
server_name www.aaa.com; # www.aaa.com域名
location / {
proxy_pass http://localhost:8080; # 對應(yīng)端口號8080
}
}
server {
listen 80;
server_name www.bbb.com; # www.bbb.com域名
location / {
proxy_pass http://localhost:8081; # 對應(yīng)端口號8081
}
}
在服務(wù)器8080和8081分別開了一個應(yīng)用,客戶端通過不同的域名訪問,根據(jù)server_name可以反向代理到對應(yīng)的應(yīng)用服務(wù)器。
虛擬主機的原理是通過HTTP請求頭中的Host是否匹配server_name來實現(xiàn)的,有興趣的同學(xué)可以研究一下HTTP協(xié)議。
另外,server_name配置還可以過濾有人惡意將某些域名指向你的主機服務(wù)器。
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結(jié)尾的請求通過FashCGI交給PHP-FPM處理,PHP-FPM是PHP的一個FastCGI管理器。有關(guān)FashCGI可以查閱其他資料,本文不再介紹。
fastcgi_pass和proxy_pass有什么區(qū)別?下面一張圖帶你看明白:
