Nginx(發(fā)音同engine x)是異步框架的網頁服務器,也可以用作反向代理、負載平衡器和HTTP緩存
Nginx在官方測試的結果中,能夠支持五萬個并行連接,而在實際的運作中,可以支持二萬至四萬個并行連接。
這里我們講解一下將nginx用作反向代理、負載平衡器和HTTP緩存(靜態(tài)資源服務器)的方法
反向代理
使用反向代理主要的方式是使用 proxy_pass 配置
location /api/admin {
proxy_pass http://server-test;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
負載平衡器
負載均衡可使用upstream 配置多個轉發(fā)服務器
upstream server-test {
server 10.196.1.1:8930;
server 10.196.1.2:8930;
}
然后參考反向代理的配置,proxy_pass 轉發(fā)到對應 upstream
HTTP緩存
在http模塊中,配置root屬性,屬性值為靜態(tài)資源根路徑。如下圖所示,nginx默認的靜態(tài)頁面即以此方式配置。
root /usr/share/nginx/html;
在root配置好后,我們也需要使用location 來匹配資源路徑,如下所示,我們使用根路徑做匹配。當我們訪問
test.com/index.html 時,nginx 便會查找 /usr/share/nginx/html/index.html
開啟索引: 使用autoindex 屬性可以開啟索引, 開啟索引情況下,可以以目錄的方式遍歷資源靜態(tài)資源子路徑。配置方式如下:
autoindex:開啟索引
autoindex_exact_size: 索引顯示文件大小
autoindex_localtime: 索引顯示時間
location / { # 可有多個 location 用于配置路由地址
autoindex on;
autoindex_exact_size on;
autoindex_localtime on;
}
訪問路徑時,得到的效果如下所示:

通過nginx訪問靜態(tài)資源目錄
http {
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include /etc/nginx/mime.types;
default_type application/octet-stream;
# Load modular configuration files from the /etc/nginx/conf.d directory.
# See http://nginx.org/en/docs/ngx_core_module.html#include
# for more information.
include /etc/nginx/conf.d/*.conf;
upstream hsh-test {
server 10.196.1.1:8199;
}
upstream hlife-manager-test {
server 10.196.1.1:8930;
}
server {
listen 8080 default_server;
listen [::]:8080 default_server;
server_name _;
root /usr/share/nginx/html;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
location /api/admin {
proxy_pass http://hsh-test;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
}