Nginx配置文件优化
2016-01-27 15:08
579 查看
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;
#autoindex on;
tcp_nopush on;
tcp_nodelay on;
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 ;
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;
}
}
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代理指定目录
- 访问Nginx发生SSL connection error的一种情况
- Nginx+Naxsi部署专业级Web应用防火墙
- CentOS 6.2实战部署Nginx+MySQL+PHP
- nginx中http核心模块的配置指令2
- nginx中http核心模块的配置指令3
- nginx中http核心模块的配置指令4
- nginx中http的fastcgi模块的配置指令1
- Nginx 学习笔记(一)
- [游戏资讯]《极品飞车16:亡命狂飙》配置需求公布
- 配置文件神器 typesafe conf 用法简介
- 配置文件神器 typesafe conf 用法简介
- 网站502与504错误分析
- 路由器备份配置
- 路由器的基本配置
- 路由器基础配置及传输协议
- 经典配置 Vlan篇
- 备份线路的配置