簡單談談Nginx基礎知識入門
Nginx 是一個高性能的 HTTP 和反向代理服務器,以高穩(wěn)定性、豐富的功能集、示例配置文件和低系統(tǒng)資源的消耗而聞名。
Nginx 特點 處理靜態(tài)文件,索引文件以及自動索引;打開文件描述符緩沖. 無緩存的反向代理加速,簡單的負載均衡和容錯. FastCGI,簡單的負載均衡和容錯. 模塊化的結構。包括 gzipping, byte ranges, chunked responses,以及 SSI-filter 等 filter。如果由 FastCGI 或其它代理服務器處理單頁中存在的多個 SSI,則這項處理可以并行運行,而不需要相互等待。 支持 SSL 和 TLSSNI. 主要應用場合 1、靜態(tài) HTTP 服務器
首先,Nginx是一個 HTTP 服務器,可以將服務器上的靜態(tài)文件(如 HTML、圖片)通過 HTTP 協(xié)議展現(xiàn)給客戶端。
配置:
server {
listen 80; # 端口號
location / {
root /usr/share/nginx/html; # 靜態(tài)文件路徑
}
}
2、反向代理服務器
什么是反向代理?
客戶端本來可以直接通過 HTTP 協(xié)議訪問某網(wǎng)站應用服務器,如果網(wǎng)站管理員在中間加上一個 Nginx,客戶端請求Nginx,Nginx 請求應用服務器,然后將結果返回給客戶端,此時 Nginx 就是反向代理服務器。

配置:
server {
listen 80;
location / {
proxy_pass http://192.168.20.1:8080; # 應用服務器HTTP地址
}
}
既然服務器可以直接 HTTP 訪問,為什么要在中間加上一個反向代理,不是多此一舉嗎?反向代理有什么作用?繼續(xù)往下看,下面的負載均衡、虛擬主機,都基于反向代理實現(xiàn),當然反向代理的功能也不僅僅是這些。
3、負載均衡
當網(wǎng)站訪問量非常大,網(wǎng)站站長開心賺錢的同時,也攤上事兒了。因為網(wǎng)站越來越慢,一臺服務器已經(jīng)不夠用了。于是將相同的應用部署在多臺服務器上,將大量用戶的請求分配給多臺機器處理。同時帶來的好處是,其中一臺服務器萬一掛了,只要還有其他服務器正常運行,就不會影響用戶使用。
當我們網(wǎng)站進行大的升級更新時,我們不可能直接將所有的服務器都關掉,然后再升級的。通常我們都是批量的關掉一些服務器,去升級網(wǎng)站,當有用戶的請求時則分配給其他還在運作的機器處理。當之前關掉的機器更新完成后,再次開啟,然后又批量關掉部分機器,如上循環(huán),直到最后全部機器都更新完成。這樣就不會影響用戶使用。
Nginx 可以通過反向代理來實現(xiàn)負載均衡。

配置:
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、虛擬主機
網(wǎng)站訪問量大,需要負載均衡。然而并不是所有網(wǎng)站都如此出色,有的網(wǎng)站,由于訪問量太小,需要節(jié)省成本,將多個網(wǎng)站部署在同一臺服務器上。
例如將 www.aaa.com 和 www.bbb.com 兩個網(wǎng)站部署在同一臺服務器上,兩個域名解析到同一個 IP 地址,但是用戶通過兩個域名卻可以打開兩個完全不同的網(wǎng)站,互相不影響,就像訪問兩個服務器一樣,所以叫兩個虛擬主機。
配置:
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; # 對應端口號8080
}
}
server {
listen 80;
server_name www.bbb.com; # www.bbb.com域名
location / {
proxy_pass http://localhost:8081; # 對應端口號8081
}
}
在服務器 8080 和 8081 兩個端口分別開了一個應用,客戶端通過不同的域名訪問,根據(jù) server_name 可以反向代理到對應的應用服務器。
虛擬主機的原理是通過 HTTP 請求頭中的 Host 是否匹配 server_name 來實現(xiàn)的,有興趣的同學可以研究一下 HTTP 協(xié)議。
另外,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 有什么區(qū)別?下面一張圖帶你看明白:

相關文章
如何利用nginx處理DDOS進行系統(tǒng)優(yōu)化詳解
防御DDOS是一個系統(tǒng)工程,攻擊花樣多,防御的成本高瓶頸多,防御起來即被動又無奈,下面這篇文章主要給大家介紹了關于如何利用nginx處理DDOS進行系統(tǒng)優(yōu)化的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2018-08-08

