深刻Nginx之《经常使用参数配置技巧》

常见参配置实战技巧css

    下面会讲解实战中应该怎么配置更为合理。html


 

1.usernode

    默认是nobody,若是使用nobody,Nginx在运行过程当中会出现不少操做没有权限,好比写硬盘。通常都是用低于root级别的用户,好比www,而且能够在linux下设置www禁止ssh登陆服务器,提升安全性;linux

 

2.worker_processesnginx

    表明Nginx worker的进程数,通常状况下建议和机器的核数相同,也能够配置 worker_processes auto ; (Nginx1.2.5版本添加的) 自动根据cpu核数进行进程启动;后端

    可是实际应用中,服务器不必定只跑了Nginx,须要考虑机器资源会被分配到哪些服务上,避免进程启动过多,和其余服务竞争cpu,致使过多上下文切换;浏览器

 

3.worker_cpu_affinity auto缓存

Nginx 1.9.10添加的功能,表示能够根据服务器的核数自动配cpu亲缘性,提高Nginx的性能;安全

 

四、error_log & access_log服务器

关于日志记录的,error_log 配置为error级别, 减小没必要要的日志记录, 若是是测试环境能够开启info级别。日志记录须要考虑硬盘的独立性,不要使用linux的根分区,避免大量的io影响Linux服务器吞吐能力。单独挂载一个磁盘,独立使用io;

另外硬盘的使用寿命须要注意,关注message的日志,按期检查硬盘(Nginx记录日志是异步处理,而且不会由于硬盘的问题,致使请求异常,可是会影响日志的记录) ;

 

5.worker_priority

    配置Nginx在linux服务器上资源使用的优先级,做为反向代理服务,应该拥有极高的优先级,建议配置到-10;

 

6.gzip_comp_level

    压缩等级,等级最高为9,等级越高压缩后的文件越小,可是消耗的cpu也会更多,通过测试,压缩等级7 和 9 的文件大小相比,其实只有细微的差异,用5-7的等级足矣;

 

7.upstream块

    配置上游服务器,能够结合 proxy_next_upstream 等指令作大量的优化,我会在下面的章节单独说明;

 

8.error_page

    错误重定向,能够捕获上游服务器错误的状态码后,将请求重定向到其它地方,好比提供友好页面,关于error_page的更强大的使用方式。

 

9.location & root

    经过root路径能够读取静态文件,在1.7.11之前的版本,Nginx读取硬盘的文件,都是阻塞型操做,后面引入了线程池,使得读取硬盘提供了非阻塞的操做,极大的提高了硬盘的io,也提高了proxy_cache的能力。

Nginx的常见配置在使用中都有着不一样的变化,那么对于更为复杂的配置来讲,其配置就显得更为精妙了,因此熟悉Nginx的官方wiki是发挥它巨大做用的基础。

 

常见配置注解


 

user  www www;   

    #定义Nginx运行的用户和用户组

worker_processes  2;    

    #Nginx进程数

worker_cpu_affinity auto;    

    #配置Nginx进程cpu亲源性

error_log  /var/log/error_log  info;    

    #全局错误日志定义类型 ,默认是error

worker_rlimit_nofile 65535;    

    #一个Nginx进程打开的最多文件描述符数量

pid /var/run/nginx.pid;    

    #进程文件

worker_priority -10;    

    #linnx系统下的资源使用的优先级

worker_rlimit_nofile  65535;    

    #worker进程的最大打开文件数限制

worker_shutdown_timeout  30;    

    #30s内Nginx没法平滑退出,就强行关闭进程

events {

  worker_connections  10000;    

    #单个进程最大链接数(整个Nginx最大链接数=链接数*进程数)

  use epoll;    

    #epoll linux2.6+内核高性能的网络io, 若是跑在FreeBSD上面,就用kqueue模型。

}

 

http {

    include       conf/mime.types;    

    #文件扩展名与文件类型映射表

    default_type  application/octet-stream;     

    #默认文件类型

    log_format main     '$remote_addr - $remote_user [$time_local] '

                         '"$request" $status $bytes_sent '

                         '"$http_referer" "$http_user_agent" '

                         ‘"$http_cookie"';   

    #定义日志格式

    client_header_buffer_size    1k;    

    #设置用户请求头所使用的buffer大小

    large_client_header_buffers  4 4k;    

    #当默认的缓冲不够用时就会使用此参数。

    server_names_hash_bucket_size 128;    

    #服务器名字的hash表大小

    client_header_buffer_size 32k;    

    #上传文件大小限制

    gzip on;    

    #开启gzip

    gzip _comp_level 6;    

    #压缩等级

    gzip _min_length  1100;    

    #设置容许压缩的页面最小字节数

    gzip _buffers     4 8k;    

    #设置系统获取几个单位的缓存用于存储gzIP的压缩结果数据流。4 8k 表明以8k为单位,按照原始数据大小以8k为单位的4倍申请内存。

    gzip _types       text/plain text/css;    

    #匹配MIME类型进行压缩

    output_buffers   2 32k;    

    #设置用于从磁盘读取响应的缓冲区的数量和大小。 此设置为:按照原始数据大小以32K为单位的2倍大小申请内存空间。

    sendfile         on;    

    #启用sendfile()函数

    tcp_nopush       on;    

    #防止网络阻塞,须要sendfile开启

    tcp_nodelay      on;    

    #防止网络阻塞,须要sendfile开启

    keepalive_timeout 90s;    

    #长链接超时时间,单位是秒

    upstream backend {

    server 192.168.1.12:8081 weight=3;

    server 192.168.1.13:8081 weight=2;

    #upstream块,weight是权重,权重越高,请求的比例越高。 

    server {

        listen       80;     

         #http监听端口

        server_name  your.example.com;  

        #域名

        access_log   /var/log/nginx.access_log  main;     

        #访问日志记录

        charset  koi8-r;    

        #默认编码

        location / {

            proxy_pass         http://backend ;

            proxy_redirect     off;

            proxy_set_header   Host             $host;

            proxy_set_header   X-Real-Ip       $remote_addr;

            proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;       }    

        #后端的应用服务器经过X-Forwarded-For获取用户的真实IP

        error_page  404  /404.html;    

        #对于后端应用服务器抛出的错误404 进行页面重定向

        location /404.html {

            root  /spool/www;

        } 

        # 匹配URL为jpg,jpeg,gif结尾的,直接去系统文件读取

        location ~* \.(jpg|jpeg|gif)$ {

            root         /spool/www;

            expires      30d;    

        #浏览器缓存的时间

        }

    }

相关文章
相关标签/搜索