天天看點

Nginx配置檔案nginx.conf詳解

#定義Nginx運作的使用者和使用者組

user ocbs ocbs;

#nginx程序數,建議設定為等于CPU總核心數。

worker_processes 8;

#全局錯誤日志定義類型,[ debug | info | notice | warn | error | crit ]

error_log /var/log/nginx/error.log info;

#程序檔案

pid /var/run/nginx.pid;

#一個nginx程序打開的最多檔案描述符數目,理論值應該是最多打開檔案數(系統的值ulimit -n)與nginx程序數相除,

但是nginx配置設定請求并不均勻,是以建議與ulimit -n的值保持一緻。

worker_rlimit_nofile 65535;

#工作模式與連接配接數上限

events

{

#參考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ]; epoll模型是Linux 2.6以上版本核心中的高性能網絡I/O模型,如果跑在FreeBSD上面,就用kqueue模型。

use epoll;

#單個程序最大連接配接數 (最大連接配接數=單個程序連接配接數*程序數)

worker_connections 65535;

}

#設定http伺服器

http

include mime.types;                    #檔案擴充名與檔案類型映射表

default_type application/octet-stream; #預設檔案類型

#charset utf-8;                                       #預設編碼

server_names_hash_bucket_size 128;     #伺服器名字的hash表大小

client_header_buffer_size 32k;               #上傳檔案大小限制

large_client_header_buffers 4 64k;     #設定請求緩

client_max_body_size 8m;               #設定請求最大緩

sendfile on;       #開啟高效檔案傳輸模式,sendfile指令指定nginx是否調用sendfile函數來輸出檔案,

                         對于普通應用設為 on,如果用來進行下載下傳等應用磁盤IO重負載應用,可設定為off,

             以平衡磁盤與網絡I/O處理速度,降低系統的負載。注意:如果圖檔顯示不正常把這個改成off。

autoindex on;                            #開啟目錄清單通路,合适下載下傳伺服器,預設關閉。

tcp_nopush on;                         #防止網絡阻塞

tcp_nodelay on;                        #防止網絡阻塞

keepalive_timeout 120;            #長連接配接逾時時間,機關是秒

#FastCGI相關參數是為了改善網站的性能:減少資源占用,提高通路速度。下面參數看字面意思都能了解。

fastcgi_connect_timeout 300;

fastcgi_send_timeout 300;

fastcgi_read_timeout 300;

fastcgi_buffer_size 64k;

fastcgi_buffers 4 64k;

fastcgi_busy_buffers_size 128k;

fastcgi_temp_file_write_size 128k;

#gzip子產品設定

gzip on;                      #開啟gzip壓縮輸出

gzip_min_length 1k;    #最小壓縮檔案大小

gzip_buffers 4 16k;    #壓縮緩沖區

gzip_http_version 1.0; #壓縮版本(預設1.1,前端如果是squid2.5請使用1.0)

gzip_comp_level 2;     #壓縮等級

gzip_types text/plain application/x-javascript text/css application/xml;

#壓縮類型,預設就已經包含text/html,是以下面就不用再寫了,寫上去也不會有問題,但是會有一個warn。

gzip_vary on;

#limit_zone crawler $binary_remote_addr 10m; #開啟限制IP連接配接數的時候需要使用

#upstream的負載均衡,weight是權重,可以根據機器配置定義權重。weigth參數表示權值,權值越高被配置設定到的幾率越大。

server 192.168.10.128:1983 weight=3;

server 192.168.10.129:1983 weight=2;

server 192.168.80.130:1983 weight=3;

#虛拟主機的配置

server

    #監聽端口預設為80

    listen 1983;

    #域名可以有多個,用空格隔開

    server_name  www.yuri.com;

    index index.html index.htm index.php;

    root /home/ocbs/data;

    location ~ .*\.(php|php5)?$

    {

    fastcgi_pass 127.0.0.1:9000;

    fastcgi_index index.php;

    include fastcgi.conf;

    }

    #圖檔緩存時間設定

    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$

    expires 10d;

    #JS和CSS緩存時間設定

    location ~ .*\.(js|css)?$

    expires 1h;

    #日志格式設定

    log_format access '$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/ha97access.log access;

    #對 "/" 啟用反向代理

    location / {

    proxy_redirect off;

    proxy_set_header X-Real-IP $remote_addr;

    #後端的Web伺服器可以通過X-Forwarded-For擷取使用者真實IP

    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    #以下是一些反向代理的配置,可選。

    proxy_set_header Host $host;

    client_max_body_size 10m;     #允許用戶端請求的最大單檔案位元組數

    client_body_buffer_size 128k; #緩沖區代理緩沖使用者端請求的最大位元組數,

    proxy_connect_timeout 90;     #nginx跟後端伺服器連接配接逾時時間(代理連接配接逾時)

    proxy_send_timeout 90;        #後端伺服器資料回傳時間(代理發送逾時)

    proxy_read_timeout 90;        #連接配接成功後,後端伺服器響應時間(代理接收逾時)

    proxy_buffer_size 4k;         #設定代理伺服器(nginx)儲存使用者頭資訊的緩沖區大小

    proxy_buffers 4 32k;          #proxy_buffers緩沖區,網頁平均在32k以下的設定

    proxy_busy_buffers_size 64k;  #高負荷下緩沖大小(proxy_buffers*2)

    proxy_temp_file_write_size 64k;

    #設定緩存檔案夾大小,大于這個值,将從upstream伺服器傳

    #設定檢視Nginx狀态的位址

    location /NginxStatus {

    stub_status on;

    access_log on;

    auth_basic "NginxStatus";

    auth_basic_user_file conf/htpasswd;

    #htpasswd檔案的内容可以用apache提供的htpasswd工具來産生。

    #本地動靜分離反向代理配置

    #所有jsp的頁面均交由tomcat或resin處理

    location ~ .(jsp|jspx|do)?$ {

    #所有靜态檔案由nginx直接讀取不經過tomcat或resin

    location ~ .*.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$

    { expires 15d; }

    location ~ .*.(js|css)?$

    { expires 1h; }

本文轉自 yuri_cto 51CTO部落格,原文連結:http://blog.51cto.com/laobaiv1/1952417,如需轉載請自行聯系原作者

繼續閱讀