nginx 配置文件

nginx的配置文件是 nginx.conf,按照上一篇的配置,是在 /opt/programs/tengine/conf 目录下。

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

 #nginx进程数,建议设置为等于CPU总核心数 = CPU数 * 核数,如果有4个双核CPU,则可设置为 4*2=8。
 worker_processes 8;

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

 #进程文件
 pid /var/run/nginx.pid;

 #一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,

#但是nginx分配请求并不均匀,所以建议与ulimit -n的值保持一致。
 worker_rlimit_nofile 65535;

 

#工作模式与连接数上限
 events
 {
    # 参考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ];
    # epoll模型是Linux 2.6以上版本内核中的高性能网络I/O模型,如果跑在FreeBSD上面,就用kqueue模型。
 use epoll;

   #单个后台worker process进程的最大并发链接数
   # 并发总数是 worker_processes 和 worker_connections 的乘积
   # 即 max_clients = worker_processes * worker_connections
   # 在设置了反向代理的情况下,max_clients = worker_processes * worker_connections / 4 
   # 为什么上面反向代理要除以4,应该说是一个经验值
   # 根据以上条件,正常情况下的Nginx Server可以应付的最大连接数为:8 * 4000 = 32000 (4000是下面设的值)
   # worker_connections 值的设置跟物理内存大小有关
   # 因为并发受IO约束,max_clients 的值须小于系统可以打开的最大文件数
   # 而系统可以打开的最大文件数和内存大小成正比,一般1GB内存的机器上可以打开的文件数大约是10万左右
   # 我们来看看360M内存的VPS可以打开的文件句柄数是多少:
   # $ cat /proc/sys/fs/file-max
   # 输出 34336
   # 32000 < 34336,即并发连接总数小于系统可以打开的文件句柄总数,这样就在操作系统可以承受的范围之内
   # 所以,worker_connections 的值需根据 worker_processes 进程数目和系统可以打开的最大文件总数进行适当地进行设置
   # 使得并发总数小于操作系统可以打开的最大文件数目
   # 其实质也就是根据主机的物理CPU和内存进行配置
   # 当然,理论上的并发总数可能会和实际有所偏差,因为主机还有其他的工作进程需要消耗系统资源。
   # ulimit -SHn 65535

 worker_connections 4000;
 }

 

#设定http服务器
 http
 {
     include mime.types;     #文件扩展名与文件类型映射表
     default_type application/octet-stream;      #默认文件类型
     #charset utf-8;      #默认编码
     server_names_hash_bucket_size 128;      #服务器名字的hash表大小
     client_header_buffer_size 32k;     #上传文件大小限制
     large_client_header_buffers 4 64k;     #设定请求缓
     client_max_body_size 8m;     #设定请求缓
     sendfile on;     #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来
                            #输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置
                            #为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。
     autoindex on;                #开启目录列表访问,合适下载服务器,默认关闭。
     tcp_nopush on;     #防止网络阻塞
     tcp_nodelay on;     #防止网络阻塞
     keepalive_timeout 120;     #长连接超时时间,单位是秒

     #gzip模块设置
     gzip on;     #开启gzip压缩输出 
     gzip_min_length 1k;     #最小压缩文件大小
     gzip_buffers 4 16k;     #压缩缓冲区
     gzip_http_version 1.0;     #压缩版本(默认1.1,前端如果是squid2.5请使用1.0)
     gzip_comp_level 2;     #压缩等级
     gzip_types text/plain application/x-javascript text/css application/xml;
     #压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。
     gzip_vary on;
     #limit_zone crawler $binary_remote_addr 10m;     #开启限制IP连接数的时候需要使用

     #虚拟主机的配置

    server
    {  #监听端口
        listen 80;
        #域名可以有多个,用空格隔开
        server_name www.ha97.com ha97.com;
        index index.html index.htm index.jsp;
        root /data/www/ha97;
        location /
        {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.jsp;
            include fastcgi.conf;
        }

    }

 }

 

最后,我们可以在 http://tengine.taobao.org/nginx_docs/cn/ 上看中文版的关于 nginx 的配置说明

 

posted @ 2018-02-24 16:36  一剑侵心  阅读(188)  评论(0)    收藏  举报