Nginx配置檔案示例解析

技術小甜發表於2017-11-15

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;0

    #設定日誌格式

    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;


        #設定本虛擬主機的訪問日誌

        access_log  logs/nginx.access.log  main;


        #預設請求

        location / {


         #定義伺服器的預設網站根目錄位置

            root html;

            #定義首頁索引檔案的名稱

            index index.php index.html index.htm;   


        }


        # 定義錯誤提示頁面

        error_page   500 502 503 504 /50x.html;

        location = /50x.html {

        root html;

        }


        #靜態檔案,nginx自己處理

        location ~ ^/(images|javascript|js|css|flash|media|static)/ {


            #過期30天,靜態檔案不怎麼更新,過期可以設大一點,

            #如果頻繁更新,則可以設定得小一點。

            expires 30d;

        }

       若果訪問URL中以.php結尾,請求轉發給127.0.0.1伺服器,proxy_pass 實現代理功能

       location ~ .php$ {

          proxy_pass http://127.0.0.1;

        }

     #PHP 指令碼請求全部轉發到 FastCGI處理. 使用FastCGI預設配置.

        location ~ .php$ {

         root html;

            fastcgi_pass 127.0.0.1:9000;

            fastcgi_index index.php;

            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;

            include fastcgi_params;

        }


        #禁止訪問 .ht檔案

            location ~ /.ht {

            deny all;

        }

    }

}


本文轉自super李導51CTO部落格,原文連結:http://blog.51cto.com/superleedo/1890317 ,如需轉載請自行聯絡原作者


相關文章