nginx配置檔案結構

nginx配置檔案結構
1 Star2 Stars3 Stars4 Stars5 Stars 給文章打分!
Loading...

nginx配置檔案結構

配置例項

#執行使用者
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
# 在設定了反向代理的情況下,max_clients = worker_processes * worker_connections / 4  為什麼
# 為什麼上面反向代理要除以4,應該說是一個經驗值
# 根據以上條件,正常情況下的Nginx Server可以應付的最大連線數為:4 * 8000 = 32000
# worker_connections 值的設定跟實體記憶體大小有關
# 因為併發受IO約束,max_clients的值須小於系統可以開啟的最大檔案數
# 而系統可以開啟的最大檔案數和記憶體大小成正比,一般1GB記憶體的機器上可以開啟的檔案數大約是10萬左右
# 我們來看看360M記憶體的VPS可以開啟的檔案控制代碼數是多少:
# $ cat /proc/sys/fs/file-max
# 輸出 34336
# 32000 < 34336,即併發連線總數小於系統可以開啟的檔案控制代碼總數,這樣就在作業系統可以承受的範圍之內
# 所以,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;
#定義伺服器的預設網站根目錄位置
root html;
#設定本虛擬主機的訪問日誌
access_log  logs/nginx.access.log  main;
#預設請求,優先順序最低的匹配
location / {
# 匹配任何請求,因為所有請求都是以"/"開始
# 但是更長字元匹配或者正規表示式匹配會優先匹配
#定義首頁索引檔案的名稱
index index.php index.html index.htm;
}
#1. = 精確匹配會第一個被處理。如果發現精確匹配,nginx停止搜尋其他匹配。
location  = / {
# 只匹配"/".
}
# 定義錯誤提示頁面
error_page   500 502 503 504 /50x.html;
location = /50x.html {
}
#靜態檔案,nginx自己處理
#2.波浪線表示執行一個正則匹配,區分大小寫
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;
}
#3.^~ 則只匹配該規則,nginx停止搜尋其他匹配,否則nginx會繼續處理其他location指令。
location ^~ /images/ {
# 匹配任何以 /images/ 開始的請求,並停止匹配 其它location
#[Configuration C]
}
#4.~*    #表示執行一個正則匹配,不區分大小寫
location ~* .(gif|jpg|jpeg)$ {
# 匹配以 gif, jpg, or jpeg結尾的請求.
# 但是所有 /images/ 目錄的請求將由 [Configuration C]處理.
}
}
}

doc

nginx基本配置與引數說明

相關文章

程式語言 最新文章