#user www www; #指定nginx进程运行用户以及用户组
worker_processes 8;#nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu计为8)。
#全局错误日志文件
#debug输出日志最为详细,而crit输出日志最少/var/log目录是linux下的日志存放目录
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;#指定进程id的存储位置
worker_rlimit_nofile 65535;#这个指令是指当一个nginx 进程打开的最多文件描述符数目,理论值应该是最多打开文
#件数(ulimit -n)与nginx 进程数相除,但是nginx 分配请求并不是那么均匀,所以最好与ulimit -n 的值保持一致。
#现在在linux 2.6内核下开启文件打开数为65535,worker_rlimit_nofile就相应应该填写65535。
events #nginx的工作模式及连接输上线
{
use epoll; #nginx工作模式,epoll是linux平台下的高效模式
worker_connections 65535;#定义nginx每个进程的最大连接数为51200,一般网上都配置65535
}
http
{
include mime.types; #实现对配置文件所包含的文件的设定
default_type application/octet-stream;#设置默认类型为二进制流
fastcgi_intercept_errors on;
charset utf-8;
server_names_hash_bucket_size 128;
client_header_buffer_size 32k;#指定来自客户端请求头的headerbuffer大小,设置为32KB
large_client_header_buffers 4 32k;#指定客户端请求中较大的消息头的缓存最大数量和大小,这里是4个32KB
client_max_body_size 300m;#上传文件大小
#开启高效模式文件传输模式,将tcp_nopush和tcp_nodely两个指另设置为on,用于防止网络阻塞。
sendfile on;
tcp_nopush on;
tcp_nodelay on;
#设置客户端连接保持活动的超时时间
keepalive_timeout 60;
#客户端请求主体读取缓存
client_body_buffer_size 512k;
proxy_connect_timeout 5;
proxy_read_timeout 60;
proxy_send_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
proxy_temp_file_write_size 128k;
#开启gzip
gzip on;
#允许压缩的最小字节数
gzip_min_length 1k;
#4个单位为16k的内存作为压缩结果流缓存
gzip_buffers 4 16k;
#设置识别HTTP协议版本,默认是1.1
gzip_http_version 1.1;
#gzip压缩比,可在1~9中设置,1压缩比最小,速度最快,9压缩比最大,速度最慢,消耗CPU
gzip_comp_level 2;
#压缩的类型
gzip_types text/plain application/x-javascript text/css application/xml;
#让前端的缓存服务器混村经过的gzip压缩的页面
gzip_vary on;
#日志格式
log_format main '$http_x_forwarded_for - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" $request_time $remote_addr';
#负载均衡
upstream web_app {
#ip_hash; #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器
server 192.168.1.100:8080;
server 192.168.1.101:8080;
}
upstream web_app2 {
#ip_hash; #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器
server 192.168.1.85:8081;
server 192.168.1.87:8081;
}
####
server {
listen 80;
server_name localhost; # 对应你的域名
index index.jsp index.html index.htm;
location /
{
proxy_next_upstream http_502 http_504 error timeout invalid_header;
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://web_app/Test/;
expires 3d;
}
}
server {
listen 8696;
server_name localhost; # 对应你的域名
index index.jsp index.html index.htm;
location /
{
proxy_next_upstream http_502 http_504 error timeout invalid_header;
proxy_set_header Host $host:8696;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://web_app2/Test/;
expires 3d;
}
}
}
访问 192.168.1.102 和 192.168.1.104:8696