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