• 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 的配置说明

  • 相关阅读:
    node 牛逼博客
    NodeJs断点调试详细说明
    .NET 7 中 LINQ 的疯狂性能提升
    nodejs加断点调试方法
    Mac安装mysql新手小白教程
    如何看待由react router原班人马打造并获得三百万美元融资的ts全栈开发框架remix?
    什么是真正的程序员
    测速工具使用心得体会
    SWIG:SWIG的简介、安装、使用方法之详细攻略
    node+yog2+swig
  • 原文地址:https://www.cnblogs.com/langfanyun/p/8466546.html
Copyright © 2020-2023  润新知