Nginx配置參數

Nginx配置參數

主配置文件

通常情況下,nginx的主配置文件都在 /usr/local/nginx/conf/nginx.conf
#表示註釋
;表示一條命令

#定義Nginx運行的用戶和用戶組  
user www www;  

#nginx進程數,建議設置爲等於CPU總核心數。  
worker_processes 2;  

#全局錯誤日誌定義類型,[ debug | info | notice | warn | error | crit ]  
#從左到右記錄的日誌依次見少,debug最多,crit最少
error_log /home/wwwlogs/nginx_error.log  crit; 

#進程文件  
pid /usr/local/nginx/logs/nginx.pid; 

#一個nginx進程打開的最多文件描述符數目
worker_rlimit_nofile 65535;  

#事件模型
events  
{  
    #參考事件模型,kqueue | rtsig | epoll | /dev/poll | select | poll  
    #epoll模型是Linux 2.6以上版本內核中的高性能網絡I/O模型
    #如果跑在FreeBSD上面,就用kqueue模型。  
    use epoll;  
    #單個進程最大連接數(最大連接數=連接數*進程數)  
    worker_connections 65535;  
    #默認是on。設置爲on後,多個worker按串行方式來處理連接;爲off時並行處理連接
    multi_accept on;
}  

#設定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 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 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,所以下面就不用再寫了  

    upstream blog.haha.com {  
        #upstream的負載均衡,weight是權重,可以根據機器配置定義權重。
        #weigth參數表示權值,權值越高被分配到的機率越大。  
        server 192.168.80.121:80 weight=3;  
        server 192.168.80.122:80 weight=2;  
        server 192.168.80.123:80 weight=3;  
    }  

    #虛擬主機的配置,一個server對應一個虛擬主機 
    server  
    {  
        #監聽端口  
        listen 80;  
        #域名可以有多個,用空格隔開  
        server_name www.haha.com haha.com;  
        index index.html index.htm index.php;  
        root /data/www/haha;  
        location ~ \.php$  
        {  
            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;  
        }     
        #定義本虛擬主機的訪問日誌  
        access_log ar/loginx/hahaaccess.log access;  

        #對 "/" 啓用反向代理  
        location / {  
            proxy_pass http://127.0.0.1:88;  
            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服務器傳  
        }  

        #本地動靜分離反向代理配置   
        location ~ \.(php)$ {  
            proxy_set_header Host $host;  
            proxy_set_header X-Real-IP $remote_addr;  
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
            proxy_pass http://127.0.0.1:8080;  
        }  
        #所有靜態文件由nginx直接讀取  
        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; }  
    }  
}  

配置虛擬主機

說明:配置文件若都放在主配置文件中,勢必會比較大,我們可以將配置文件放到一個指定的位置(vhost),然後將這些配置文件包含進來即可(在http模塊的最後添加:include vhost/*.conf;)。

cd /usr/local/nginx/conf
mkdir vhost 
cd vhost
vim www.test.com.conf
server {
        listen 80;
        server_name www.test.com test.com;
        index index.html index.htm index.php;
        root /var/www/html;
        #一下代碼可以設置nginx支持PHP解析
        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;
        }
}
需要重啓nginx:service nginx restart
或者重新加載配置:service nginx reload  #可以不間斷服務的更新配置
域名訪問:需要域名解析或者本地劫持
    10.36.137.44    www.test.com
    10.36.137.44    test.com
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章