Nginx配置文件优化

nginx.conf 主配置文件:

user    web web;    #nginx运行用户和组

worker_processes 8;      #主进程数量

worker_rlimit_nofile 102400;    #文件句柄数量


error_log    /usr/local/nginx/logs/nginx_error.log    crit;    #错误日志

pid            /var/run/nginx.pid;


events

{
         use epoll;    #使用epoll模型

         worker_connections 102400;  #最大并发连接数
}

http

{

         include           mime.types;

         default_type    application/octet-stream;

         charset utf-8;    #默认字符集

         server_names_hash_bucket_size 256;    #服务器名字的hash表大小

         client_header_buffer_size 256k;    #上传文件的大小限制

         large_client_header_buffers 4 256k;    #设定头部请求缓存大小

         client_max_body_size           50m;    #允许客户端请求的最大单文件字节数         

         client_body_buffer_size        256k;   #缓冲区代理缓冲用户端请求的最大字节数

         client_header_timeout     3m;    #设定客户端请求的头部超时时间

         client_body_timeout 3m;    #设定客户端请求的主体超时时间

         send_timeout             3m;    #指定客户端的响应超时时间。这个设置不会用于整个转发器,而是在两次客户端读取操作之间。如果在这段时间内,客户端没有读取任何数据,nginx就会关闭连接。   

         sendfile on;    #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改 成off。

        

         #autoindex on;    #开启目录列表访问,合适下载服务器,默认关闭。

         tcp_nopush on;    #防止网络阻塞,告诉nginx在一个数据包里发送所有头文件,而不是一个接一个的发送。

         tcp_nodelay on;    #防止网络阻塞,告诉nginx不要缓存数据,而是一段一段的发送--当需要及时发送数据时,就应该给应用设置这个属性,这样发送一小块数据信息时就不能立即得到返回值。

         keepalive_timeout 120;    #长连接超时时间,单位是秒


         include                    vhosts/upstream.conf;

         include                    vhosts/www.linux.com.conf;
}


upstream.conf配置文件

upstream www.linux.com {

    #配置后端的web服务器,可以加权重weight,weight数字越大,分到的请求就越多

    server 192.168.1.100:80;    

    server 192.168.1.101:80;

    server 192.168.1.102:80;

    #server 192.168.1.104:80 weight=5;    

    #server 192.168.1.105:80 weight=4;

    }


www.linux.com.conf配置文件
server {

    listen             80;

    server_name    www.linux.com;
    charset utf-8;

    index index.html index.htm;

    root    /home/web/;


    location ~ ^/nginxstatus {

        stub_status on;

        access_log off;

    }

    location / {

             proxy_redirect off ;

             #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP

             proxy_set_header Host $host;

             proxy_set_header X-Real-IP $remote_addr;    

             proxy_set_header REMOTE-HOST $remote_addr;

             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;


             client_max_body_size 50m;    #允许客户端请求的最大单文件字节数   

             client_body_buffer_size 256k;    #缓冲区代理缓冲用户端请求的最大字节数

             proxy_connect_timeout 30;    #nginx跟后端服务器连接超时时间(代理连接超时)

             proxy_send_timeout 30;    #后端服务器数据回传时间(代理发送超时)

             proxy_read_timeout 60;    #连接成功后,后端服务器响应时间(代理接收超时)

             proxy_buffer_size 256k;    #设置代理服务器(nginx)保存用户头信息的缓冲区大小

             proxy_buffers 4 32k;    #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置

             proxy_busy_buffers_size 256k;    #高负荷下缓冲大小(proxy_buffers*2)

             proxy_temp_file_write_size 256k;    #设定缓存文件夹大小

             proxy_max_temp_file_size 128m;

             proxy_next_upstream error timeout invalid_header http_500 http_503 http_404;


             proxy_pass    http://www.linux.com;
             access_log  logs/www.linux.com.access.log  main;     

    }

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

        proxy_set_header Host $host;

        proxy_set_header X-Real-IP $remote_addr;

        proxy_set_header REMOTE-HOST $remote_addr;

        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        proxy_pass http://www.linux.com:80;
    }


    #js和css文件进行缓存

    location ~ .*\.(js|css)?$ {
        expires 1h;
    }


    #图片文件进行缓存
    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
        expires 10d;
    }


    #禁止访问 .ht文件
    location ~ /\.ht {
        deny all;
    }

}

你可能感兴趣的:(nginx,配置,文件优化)