标签:filename 响应时间 环境 接收 负载 超时 配置 rem auth
在此记录下Nginx服务器nginx.conf的配置文件说明, 部分注释收集于网络.
user www-data; #运行用户
worker_processes 1; #启动进程,通常设置成和cpu的数量相等
error_log /var/log/nginx/error.log; #全局错误日志及PID文件
pid /var/run/nginx.pid;
events {
use epoll; #工作模式及连接数上限#epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
worker_connections 1024;
#单个后台worker process进程的最大并发链接数
# multi_accept on;
}#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
include /etc/nginx/mime.types; #设定mime类型,类型由mime.type文件定义
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"‘;
access_log logs/access.log main; #设定日志格式
sendfile on; #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65; #连接超时时间
tcp_nodelay on;
gzip on; #开启gzip压缩
gzip_disable "MSIE [1-6]\.(?!.*SV1)";
client_header_buffer_size 1k; #设定请求缓冲
large_client_header_buffers 44k;include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
#设定负载均衡的服务器列表
upstream mysvr {
server 192.168.8.1:3128 weight=5; #本机上的Squid开启3128端口
server 192.168.8.2:80 weight=1;
server 192.168.8.3:80 weight=6; #weigth参数表示权值,权值越高被分配到的几率越大
}
server {
listen 80; #侦听80端口
server_name www.xx.com; #定义使用www.xx.com访问access_log logs/www.xx.com.access.log main;
#设定本虚拟主机的访问日志#默认请求
location / { #location允许对不同的URL使用不同的配置,即可以使用字符串也可以使用与正则表达式。
root /root; #定义服务器的默认网站根目录位置
index index.php index.html index.htm; #定义首页索引文件的名称fastcgi_pass www.xx.com;
fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
include /etc/nginx/fastcgi_params;
}
error_page 500 502 503 504 /50x.html; # 如果出现指定的http错误状态码,则返回给客户端指定的url地址。
location = /50x.html {
root /root;
}
-----------------------------------
生产环境中一例(29.70-video部分):(aaron 2011-08-11)
error_page 404 = @fetch; #如果响应错误代码的页面是php等FastCGI程序,则最好在error_page中加上等号,如本例示
location @fetch { #location项允许对不同的路径进行不同的配置。@为一命名标记,不会处理正常请求,只会处理内部重定向。
internal; #设定某个location路径只能在内部使用,不能用于外部。
proxy_store on; #存储从后端服务器传过来的文件。
proxy_next_upstream error timeout http_500 http_503 http_404;
#在哪种情况下将请求转发到负载均衡代理服务器池中的下一台服务器。
proxy_store_access user:rw group:rw all:r;
#指定用于创建文件和目录的权限。
proxy_temp_path /tmp; #指定用于缓冲较大代理请求的本地路径。
proxy_set_header Host root.video.att.xinpindao.com;
#在转发给反向代理服务器(后端)的信息中重新定义或者设置header行。(即更改转发给反向代理服务器的信息)
proxy_set_header referer http://video.att.xinpindao.com;
proxy_pass http://video.backend; #设置被代理服务器的端口或套接字,以及URL。
#default root same as server root
#root /data/attachment/video;
}
------------------------------------------
#静态文件,nginx自己处理
location ~ ^/(images|javascript|js|css|flash|media|static)/ {
root /var/www/virtual/htdocs;
expires 30d; #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
}
#PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置.
location ~ \.php$ {
root /root;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /home/www/www$fastcgi_script_name;
include fastcgi_params;
}
#设定查看Nginx状态的地址
location /NginxStatus {
stub_status on;
access_log on;
auth_basic "NginxStatus";
auth_basic_user_file conf/htpasswd;
}
#禁止访问 .htxxx 文件
location ~ /\.ht {
deny all;
}
}
}
以上是一些基本的配置,使用Nginx最大的好处就是负载均衡
如果要使用负载均衡的话,可以修改配置http节点如下:
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
include /etc/nginx/mime.types; #设定mime类型,类型由mime.type文件定义
default_type application/octet-stream;
access_log /var/log/nginx/access.log; #设定日志格式#省略上文有的一些配置节点
#。。。。。。。。。。
#设定负载均衡的服务器列表
upstream mysvr { #upstream指令用于设置一组可以在proxy_pass指令中使用的代理服务器,默认的代理方式为轮询。
server 192.168.8.1x:3128 weight=5;#本机上的Squid开启3128端口
server 192.168.8.2x:80 weight=1; #server指令用于指定后端服务器的名称和参数。
server 192.168.8.3x:80 weight=6; #weigth参数表示权值,权值越高被分配到的几率越大
}upstream mysvr2 {
server 192.168.8.x:80 weight=1;server 192.168.8.x:80 weight=6; #weigth参数表示权值,权值越高被分配到的几率越大
}#第一个虚拟服务器
server { #在server{...}虚拟主机内可通过proxy_pass指令设置关于反向代理的upstream服务器集群。
listen 80; #侦听192.168.8.x的80端口
server_name 192.168.8.x;
location ~ .*\.aspx$ { #对aspx后缀的进行负载均衡请求root /root; #定义服务器的默认网站根目录位置
index index.php index.html index.htm; #定义首页索引文件的名称proxy_pass http://mysvr ; #请求转向mysvr 定义的服务器列表
#以下是一些反向代理的配置可删除.
proxy_redirect off;
#后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m; #允许客户端请求的最大单文件字节数
client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数,
proxy_connect_timeout 90; #nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 90; #后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传}
}
}
标签:filename 响应时间 环境 接收 负载 超时 配置 rem auth
原文地址:http://www.cnblogs.com/wangzhilei/p/7220318.html