您的位置:首页 > 运维架构 > Nginx

nginx.conf 配置文件详解

2015-11-18 18:15 585 查看
nginx.conf 配置文件详解

user  root;
#定义Nginx运行的用户和用户组

worker_processes  2;
#nginx进程数,建议设置为等于CPU总核心数。

worker_rlimit_nofile 10240;
#一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,但是nginx分配请求并不均匀,所以建议与ulimit -n的值保持一致。

error_log logs/nginx_error.log  crit;
#全局错误日志定义类型,[ debug | info | notice | warn | error | crit ]

events{
use epoll;
#epoll模型是Linux 2.6以上版本内核中的高性能网络I/O模型,如果跑在FreeBSD上面,就用kqueue模型。

worker_connections 2048;
}

http {
include       mime.types;
#文件扩展名与文件类型映射表

default_type  application/octet-stream;
#默认文件类型

log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
#日志格式设定
$remote_addr 和 $http_x_forwarded_for:记录客户端的ip地址。
$remote_user:记录客户端用户名称。
$time_local:记录访问时间与时区  18/Jul/2012:17:00:01 +0800。
$request:记录请求的URL与HTTP协议 “GET /pa/img/home/logo-alipay-t.png HTTP/1.1″。
$status:记录请求状态;成功是200。
$body_bytes_sent:记录发送给客户端文件主体内容大小。
$http_referer:记录从那个页面链接访问过来的(即:跳转来源)。
$http_user_agent:记录客户端浏览器的版本相关信息。

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

large_client_header_buffers 4 32k;
#设定请求缓

#    client_max_body_size 8m;
#设定请求缓

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

tcp_nopush on;
#防止网络阻塞

tcp_nodelay on;
#防止网络阻塞

server_tokens  off;

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

fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 128k;
#FastCGI相关参数是为了改善网站的性能:减少资源占用,提高访问速度。下面参数看字面意思都能理解。

gzip on;  #开启gzip压缩输出

gzip_min_length  1k;   #最小压缩文件大小

gzip_buffers     4 16k;  #压缩缓冲区

gzip_comp_level 2;  #压缩等级

gzip_types       text/plain application/x-javascript text/javascript text/css application/xml image/jpeg image/gif image/png;
#压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。

gzip_vary off;

#限制ip访问服务
#server {
#    listen 80 default_server;
#    server_name _;
#    return 403;
#}

server {
listen       8081;
server_name  localhost;
location / {
root   html;
index  index.html index.htm;
}

#error_page  404              /404.html;

# redirect server error pages to the static page /50x.html
#
error_page   500 502 503 504  /50x.html;
location = /50x.html {
root   html;
}

}
include vhost/*.conf;


配置nginx上图片和JS,CSS缓存时间设置

#图片缓存时间设置
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
root    /data/nginx/cache;
expires 10d;
}

#JS和CSS缓存时间设置
location ~ .*\.(js|css)?$
{
expires 1h;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: