Nginx的一些基本功能極速入門

本文主要介紹一些Nginx的最基本功能以及簡單配置,但不包括Nginx的安裝部署以及實現原理。php

一、靜態HTTP服務器html

首先,Nginx是一個HTTP服務器,能夠將服務器上的靜態文件(如HTML、圖片)經過HTTP協議展示給客戶端。配置:java

1
2
3
4
5
6
server {
     listen 80 ; # 端口號
     location / {
         root /usr/share/nginx/html; # 靜態文件路徑
     }
}

二、反向代理服務器nginx

什麼是反向代理?web

客戶端原本能夠直接經過HTTP協議訪問某網站應用服務器,網站管理員能夠在中間加上一個Nginx,服務器

客戶端請求Nginx,Nginx請求應用服務器,而後將結果返回給客戶端,此時Nginx就是反向代理服務器。app

配置:負載均衡

1
2
3
4
5
6
server {
     listen 80 ;
     location / {
         proxy_pass http: //192.168.20.1:8080; # 應用服務器HTTP地址
     }
}

既然服務器能夠直接HTTP訪問,爲何要在中間加上一個反向代理,不是畫蛇添足嗎?反向代理有什麼做用?框架

繼續往下看,下面的負載均衡、虛擬主機等,都基於反向代理實現,固然反向代理的功能也不只僅是這些。網站

三、負載均衡

當網站訪問量很是大,網站站長開心賺錢的同時,也攤上事兒了。由於網站愈來愈慢,一臺服務器已經不夠用了。

因而將同一個應用部署在多臺服務器上,將大量用戶的請求分配給多臺機器處理。同時帶來的好處是,其中一臺服

務器萬一掛了,只要還有其餘服務器正常運行,就不會影響用戶使用。Nginx能夠經過反向代理來實現負載均衡。

配置:

1
2
3
4
5
6
7
8
9
10
upstream myapp {
     server 192.168 . 20.1 : 8080 ; # 應用服務器 1
     server 192.168 . 20.2 : 8080 ; # 應用服務器 2
}
server {
     listen 80 ;
     location / {
         proxy_pass http: //myapp;
     }
}

以上配置會將請求輪詢分配到應用服務器,也就是一個客戶端的屢次請求,有可能會由多臺不一樣的服務

器處理。能夠經過ip-hash的方式,根據客戶端ip地址的hash值將請求分配給固定的某一個服務器處理。

配置:

1
2
3
4
5
6
7
8
9
10
11
upstream myapp {
     ip_hash; # 根據客戶端IP地址Hash值將請求分配給固定的一個服務器處理
     server 192.168 . 20.1 : 8080 ;
     server 192.168 . 20.2 : 8080 ;
}
server {
     listen 80 ;
     location / {
         proxy_pass http: //myapp;
     }
}

另外,服務器的硬件配置可能有好有差,想把大部分請求分配給好的服務器,

把少許請求分配給差的服務器,能夠經過weight來控制。

配置:

1
2
3
4
5
6
7
8
9
10
upstream myapp {
     server 192.168 . 20.1 : 8080 weight= 3 ; # 該服務器處理 3 / 4 請求
     server 192.168 . 20.2 : 8080 ; # weight默認爲 1 ,該服務器處理 1 / 4 請求
}
server {
     listen 80 ;
     location / {
         proxy_pass http: //myapp;
     }
}

四、虛擬主機

有的網站訪問量大,須要負載均衡。然而並非全部網站都如此出色,有的網站,因爲訪問量過小,須要節省成本,將多個網站部署在同一臺服務器上。

例如將www.aaa.com和www.bbb.com兩個網站部署在同一臺服務器上,兩個域名解析到同一個IP地址,可是用戶經過兩個域名卻能夠打開兩個徹底不一樣的網站,互相不影響,就像訪問兩個服務器同樣,因此叫兩個虛擬主機。

配置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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配置還能夠過濾有人惡意將某些域名指向你的主機服務器。

五、FastCGI

Nginx自己不支持PHP等語言,可是它能夠經過FastCGI來將請求扔給某些語言或框架處理(例如PHP、Python、Perl)。

1
2
3
4
5
6
7
8
9
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有什麼區別?下面一張圖帶你看明白:

 

相關文章
相關標籤/搜索