1. nginx.cof配置文件說明
# 運行用戶
user nobody;
# 啟動進程,通常設置成和cpu的數量相等
worker_processes 1;
# 全局錯誤日志及PID文件
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
# 工作模式及連接數上限
events {
# epoll是多路復用IO(I/O Multiplexing)中的一種方式,僅用於linux2.6以上內核,可以大大提高nginx的性能
use epoll;
# 單個后台worker process進程的最大並發鏈接數
worker_connections 1024;
# 並發總數是 worker_processes 和 worker_connections 的乘積
# 即 max_clients = worker_processes * worker_connections
# worker_connections 值的設置跟物理內存大小有關
# 因為並發受IO約束,max_clients的值須小於系統可以打開的最大文件數
# 而系統可以打開的最大文件數和內存大小成正比,一般1GB內存的機器上可以打開的文件數大約是10萬左右
# 所以,worker_connections 的值需根據 worker_processes 進程數目和系統可以打開的最大文件總數進行適當地進行設置
# 使得並發總數小於操作系統可以打開的最大文件數目
# 其實也就是根據主機的物理CPU和內存進行配置
# 當然,理論上的並發總數可能會和實際有所偏差,因為主機還有其他的工作進程需要消耗系統資源。
# ulimit -SHn 65535
}
http {
# 設定mime類型,類型由mime.type文件定義
include mime.types;
default_type application/octet-stream;
#設定日志格式
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 logs/access.log main;
# sendfile 指令指定 nginx 是否調用 sendfile 函數(zero copy 方式)來輸出文件,
# 對於普通應用,必須設為 on,
# 如果用來進行下載等應用磁盤IO重負載應用,可設置為 off,
# 以平衡磁盤與網絡I/O處理速度,降低系統的uptime.
sendfile on;
#tcp_nopush on;
# 連接超時時間
#keepalive_timeout 0;
keepalive_timeout 65;
tcp_nodelay on;
# 開啟gzip壓縮
gzip on;
gzip_disable "MSIE [1-6].";
# 設定請求緩沖
client_header_buffer_size 128k;
large_client_header_buffers 4 128k;
# 設定虛擬主機配置
server {
# 監聽80端口
listen 80;
# 定義使用 www.nginx.cn訪問
server_name www.nginx.cn;
# 允許在頭信息中使用特殊字符
ignore_invalid_headers off;
# 禁用緩存
proxy_buffering off;
# 定義服務器的默認網站根目錄位置
root html;
# 設定本虛擬主機的訪問日志
access_log logs/nginx.access.log main;
# 默認請求
location / {
# 定義首頁索引文件的名稱
index index.php index.html index.htm;
}
# 定義錯誤提示頁面
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
# 靜態文件,nginx自己處理
location ~ ^/(images|javascript|js|css|flash|media|static)/ {
# 過期30天,靜態文件不怎么更新,過期可以設大一點,
# 如果頻繁更新,則可以設置得小一點。
expires 30d;
}
# PHP 腳本請求全部轉發到 FastCGI處理. 使用FastCGI默認配置.
location ~ .php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# 禁止訪問 .htxxx 文件
location ~ /.ht {
deny all;
}
}
}
- main:用於進行nginx全局信息的配置
- events:用於nginx工作模式的配置
- http:用於進行http協議信息的一些配置
- server:用於進行服務器訪問信息的配置
- location:用於進行訪問路由的配置
- upstream:用於進行負載均衡的配置
down:表示單前的server暫時不參與負載.
weight:默認為1.weight越大,負載的權重就越大。
max_fails:允許請求失敗的次數默認為1.當超過最大次數時,返回proxy_next_upstream 模塊定義的錯誤.
fail_timeout: max_fails次失敗后,暫停的時間。Nginx基於連接探測,如果發現后端異常,在單位周期為fail_timeout設置的時間中達到max_fails次數,這個周期次數內,如果后端同一個節點不可用,那么把節點標記為不可用,並等待下一個周期(同樣時常為fail_timeout)再一次去請求,判斷是否連接是否成功。
backup:其它所有的非backup機器down或者忙的時候,請求backup機器。所以這台機器壓力會最輕。
upstream server { # 定義負載均衡設備的Ip及設備狀態
ip_hash;
server 10.0.0.11:9090 down;
server 10.0.0.11:8080 weight=2;
server 10.0.0.11:6060;
server 10.0.0.11:7070 backup;
}
2. nginx多服務配置實例
nginx.conf
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
upstream minio-server {
# weight:默認為1。weight越大,負載的權重就越大。
# backup:其它所有的非backup機器down或者忙的時候,請求backup機器。所以這台機器壓力會最輕。
# max_fails:允許請求失敗的次數默認為1,當超過最大次數時,返回 proxy_next_upstream 模塊定義的錯誤。
# fail_timeout:Nginx基於連接探測,如果發現后端異常,在單位周期為fail_timeout設置的時間中達到max_fails次數,這個周期次數內,如果后端同一個節點不可用,那么把節點標記為不可用,並等待下一個周期(同樣時常為fail_timeout)再一次去請求,判斷是否連接是否成功。
server 192.168.199.140:9000 weight=2 max_fails=3 fail_timeout=10s;
server 192.168.199.141:9000 max_fails=3 fail_timeout=30s;
}
server {
listen 80;
server_name localhost;
charset utf-8;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-For $remote_addr;
# 傳輸文件緩存大小及單次請求大小
client_body_buffer_size 10M;
client_max_body_size 1G;
# 宕機檢測,如果設置時間內無響應,則直接切換到其它服務
proxy_connect_timeout 4;
proxy_send_timeout 4;
proxy_read_timeout 4;
proxy_pass http://minio-server;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
3. 高可用負載均衡實現
此配置下 nginx + keepalived 在多台服務器上搭建,可以實現高可用負載均衡。
keepalived安裝及組合nginx配置負載實現高可用