• nginx高性能WEB服务器系列之四配置文件详解


    nginx系列友情链接:
    nginx高性能WEB服务器系列之一简介及安装
    https://www.cnblogs.com/maxtgood/p/9597596.html
    nginx高性能WEB服务器系列之二命令管理
    https://www.cnblogs.com/maxtgood/p/9597990.html
    nginx高性能WEB服务器系列之三版本升级
    https://www.cnblogs.com/maxtgood/p/9598113.html
    nginx高性能WEB服务器系列之四配置文件详解
    https://www.cnblogs.com/maxtgood/p/9598333.html
    nginx高性能WEB服务器系列之五--实战项目线上nginx多站点配置
    https://www.cnblogs.com/maxtgood/p/9598610.html
    nginx高性能WEB服务器系列之六--nginx负载均衡配置+健康检查
    https://www.cnblogs.com/maxtgood/p/9599068.html
    nginx高性能WEB服务器系列之七--nginx反向代理
    https://www.cnblogs.com/maxtgood/p/9599335.html
    nginx高性能WEB服务器系列之八--nginx日志分析与切割
    https://www.cnblogs.com/maxtgood/p/9599542.html
    nginx高性能WEB服务器系列之九--nginx运维故障日常解决方案
    https://www.cnblogs.com/maxtgood/p/9599752.html

    注:原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。

    nginx的强大之处不必要我细说,当初第一次接触nginx的时候就发现了它的强大之处,并且自我觉得非常有必要出一篇记录nginx的各个功能及坑点。

    欢迎大家对nginx感兴趣的朋友们来一起学习与及时提出错误及误点。有问题的可以在评论区@我。

    一:nginx配置文件详解

    nginx配置文件不算多,但是几乎每一层都有它精确的意思,所以要学习好nginx,必须先了解它的配置文件,接下来就解释一些nginx常用的一些配置文件的含义

    #定义Nginx运行的用户和用户组
    user  www www;
    
    #启动进程,通常设置成和cpu的数量相等 worker_processes
    8;
    #为每个进程分配cpu,上例中将8个进程分配到8个cpu,当然可以写多个,或者将一个进程分配到多个cpu。
    worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;
    
    #这个指令是指当一个nginx进程打开的最多文件描述符数目,理论值应该是最多打
    #开文件数(ulimit -n)与nginx进程数相除,但是nginx分配请求并不是那么均匀
    #,所以最好与ulimit -n的值保持一致。

    worker_rlimit_nofile 102400;
    
    
    #全局错误日志及PID文件
    error_log  /usr/local/nginx/logs/error.log; 
    #错误日志定义等级,[ debug | info | notice | warn | error | crit ]
    pid        /usr/local/nginx/nginx.pid;
    
    #一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,但是nginx分配请求并不均匀.
    #所以建议与ulimit -n的值保持一致。
    worker_rlimit_nofile 65535;
    
    #工作模式及连接数上限
    events {
        use   epoll;                 #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
        worker_connections  102400;    #单个后台worker process进程的最大并发链接数 (最大连接数=连接数*进程数)
        multi_accept on; #尽可能多的接受请求
    }
    #设定http服务器,利用它的反向代理功能提供负载均衡支持
    http {
        #设定mime类型,类型由mime.type文件定义
        include       mime.types;
        default_type  application/octet-stream;
        #设定日志格式
        access_log    /usr/local/nginx/log/nginx/access.log;
         sendfile      on;
        #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用必须设为 on
        #如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
        #autoindex  on;  #开启目录列表访问,合适下载服务器,默认关闭。
        tcp_nopush on; #防止网络阻塞
        keepalive_timeout 60;
        #keepalive超时时间,客户端到服务器端的连接持续有效时间,当出现对服务器的后,继请求时,keepalive-timeout功能可避免建立或重新建立连接。
        tcp_nodelay   on; #提高数据的实时响应性
       #开启gzip压缩
       gzip on;
        gzip_min_length  1k;
        gzip_buffers     4 16k;
        gzip_http_version 1.1;
        gzip_comp_level 2; #压缩级别大小,最大为9,值越小,压缩后比例越小,CPU处理更快。
        #值越大,消耗CPU比较高。
        gzip_types       text/plain application/x-javascript text/css application/xml;
        gzip_vary on;
        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)
        
        #设定请求缓冲
        large_client_header_buffers  4 4k;
        client_header_buffer_size 4k;
        #客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求的头部大小不会超过1k
        #不过由于一般系统分页都要大于1k,所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得。
        open_file_cache max=102400 inactive=20s;
        #这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存。
        open_file_cache_valid 30s;
        #这个是指多长时间检查一次缓存的有效信息。
        open_file_cache_min_uses 1;
        #open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的,如上例,如果有一个文件在inactive
        #包含其它配置文件,如自定义的虚拟主机
        include vhosts.conf;

    以上为简单的nginx配置详解,根据项目需求来配置,并非所有都需要,视情况而定。

    二:nginx配置文件详解(这里主要为了达到某个项目需求及作用而配置)

    #这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,test为负载均衡名称,可以任意指定
        #但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。weight配置权重,在fail_timeout内检查max_fails次数,失败则剔除均衡。(即可理解为负载均衡的安全检查,后面还会演示另种方法)
        upstream test {
            server   127.0.0.1:8080 weight=1 max_fails=2 fail_timeout=30s;
            server   127.0.0.1:8081 weight=1 max_fails=2 fail_timeout=30s;
        }
       #虚拟主机配置
        server {
            #侦听80端口
            listen       80;
            #定义使用www.maxiaotian.com访问,前提为此域名必须解析了此主机IP。
            server_name  www.maxiaotian.com;
            #设定本虚拟主机的访问日志
            access_log  logs/access.log  main;
                root   /data/webapps/maxt;  #定义服务器的默认网站根目录位置
            index index.php index.html index.htm;   #定义首页索引文件的名称
            #默认请求
            location ~ /{
              root   /data/www/maxt;      #定义服务器的默认网站根目录位置
              index index.php index.html index.htm;   #定义首页索引文件的名称
              #以下是一些反向代理的配置.
              proxy_next_upstream http_502 http_504 error timeout invalid_header;
              #如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。
              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;
               proxy_pass  http://tdt_wugk;     #请求转向后端定义的均衡模块
           }
           
            # 定义错误提示页面
                error_page   500 502 503 504 /50x.html;  
                location = /50x.html {
                root   html;
            }
            #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
            location ~ .*.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
            {
                root /data/www/maxt;
                #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力。
                expires      3d;
            }
            #PHP脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置.
            location ~ .php$ {
                root /root;
                fastcgi_pass 127.0.0.1:9000;
                fastcgi_index index.php;
                fastcgi_param SCRIPT_FILENAME /data/www/wugk$fastcgi_script_name;
                include fastcgi_params;
            }
            #设定查看Nginx状态的地址
            location /NginxStatus {
                stub_status  on;
            }
         }
    }

    大概的配置文件解释就到此了,对于一些初期接触nginx的同学肯定会觉得蒙蒙的,其实很正常,很多配置可能需要结合实践项目去认识会更快,更能理解。所以后面nginx系列文档中,我也会编写一些结合项目实践的一些配置,希望能帮到大家!

  • 相关阅读:
    mysql之左连接与右连接
    java使用AES加密解密 AES-128-ECB加密
    hive入门
    hive sequencefile导入文件遇到FAILED: SemanticException Unable to load data to destination table. Error: The file that you are trying to load does not match the file format of the destination table.错误
    hive查询遇到java.io.EOFException: Unexpected end of input stream错误
    hive内部表、外部表、分区
    hive的join查询
    hive的row_number()函数
    hive的UDF读取配置文件
    hive里的group by和distinct
  • 原文地址:https://www.cnblogs.com/maxtgood/p/9598333.html
Copyright © 2020-2023  润新知