nginx配置文件介绍

nginx配置文件介绍

nginx默认的配置文件是在安装目录下的 conf目录下,后续对 nginx 的使用基本上都是对此配置文件进行相应的修改。

配置文件中用#符号表示注释内容。

配置文件主要包括三部分,maineventshttp

main

用于进行nginx全局信息的配置。

user

定义 nginx 运行的用户和用户组,默认由 nobody 账号运行。

worker_processes

指定nginx要开启的子进程数量,通常数量是CPU内核数量的整数倍。该值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的影响。

如果是在本地运行nginx可以通过任务管理器中的性能选项中查看电脑cpu核数。

nginx配置文件介绍_第1张图片

error_log

定义错误日志文件的位置及输出级别(debug / info / notice / warn / error / crit)。

pid

用来指定进程id的存储文件的位置(windows下可以注释掉)。

worker_rlimit_nofile

用于指定一个进程可以打开最多文件数量的描述。理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,但是nginx分配请求并不均匀,所以建议与ulimit -n的值保持一致。

events

针对nginx服务器的工作模式的一些操作配置。

worker_connections

指定单个进程最大连接数(最大连接数=连接数*进程数)。该值受系统进程最大打开文件数限制,需要使用命令ulimit -n 查看当前设置。

multi_accept

配置指定nginx在收到一个新连接通知后尽可能多的接受更多的连接

use epoll

配置指定了线程轮询的方法,如果是linux2.6+,使用epoll,如果是BSDMac请使用Kqueue

http

作为web服务器,http模块是nginx最核心的一个模块,配置项也是比较多的(比如代理,日志,缓存、第三方模块等等),项目中会设置到很多的实际业务场景,需要根据硬件信息进行适当的配置。不过常规情况下,使用默认配置即可!

http {
    #文件扩展名与文件类型映射表
    #include 是个主模块指令,可以将配置文件拆分并引用,可以减少主配置文件的复杂度
    include       mime.types;
    #默认文件类型
    default_type  application/octet-stream;
    #charset utf-8; #默认编码
 
    #定义虚拟主机日志的格式
    #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指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。
    sendfile        on;
    #autoindex on; #开启目录列表访问,合适下载服务器,默认关闭。
 
    #防止网络阻塞
    #tcp_nopush     on;
 
    #长连接超时时间,单位是秒,默认为0
    keepalive_timeout  65;
 
    # 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 6; #压缩等级
    #压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。
    gzip_types text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml;
    gzip_vary on; //和http头有关系,加个vary头,给代理服务器用的,有的浏览器支持压缩,有的不支持,所以避免浪费不支持的也压缩,所以根据客户端的HTTP头来判断,是否需要压缩
    #limit_zone crawler $binary_remote_addr 10m; #开启限制IP连接数的时候需要使用
 
    # http_proxy服务全局设置
    client_max_body_size   10m;
    client_body_buffer_size   128k;
    proxy_connect_timeout   75;
    proxy_send_timeout   75;
    proxy_read_timeout   75;
    proxy_buffer_size   4k;
    proxy_buffers   4 32k;
    proxy_busy_buffers_size   64k;
    proxy_temp_file_write_size  64k;
    proxy_temp_path   /usr/local/nginx/proxy_temp 1 2;
 
}

server

配置http模块中的一个子模块,用来定义一个虚拟访问主机,也就是一个虚拟服务器的配置信息。这部分是 nginx 服务器配置中最频繁的部分,代理、缓存和日志定义等绝大多数功能和第三方模块的配置都在这里。

一个http块可以包含多个server块。

核心配置如下:

  • listen:监听端口
  • server_name:指定ip地址或者域名(可以有多个),多个配置之间用空格分隔
  • root:表示整个server虚拟主机内的根目录,所有当前主机中web项目的根目录
  • index:用户访问web网站时的全局首页
  • charset:用于设置www/路径中配置的网页的默认编码格式
  • access_log:用于指定该虚拟主机服务器中的访问记录日志存放路径
  • error_log:用于指定该虚拟主机服务器中访问错误日志的存放路径
  • error_page:指定遇到错误状态码时应展示的页面
  • location:是nginx配置中出现最多的一个配置,主要用于配置路由访问信息。在路由访问信息配置中关联到反向代理、负载均衡等等各项功能。

location

语法:location [=|~|~*|^~] /uri/ { … }

  • =: 开头表示精确匹配
  • ~: 开头表示区分大小写的正则匹配
  • ~*: 开头表示不区分大小写的正则匹配
  • !~!~*分别为区分大小写不匹配及不区分大小写不匹配的正则
  • ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url 路径即可。nginx不对url进行编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。
  • /: 通用匹配,可以匹配任何请求

可以配置多个location,不过请求的匹配也是有一定的顺序的:

  1. 匹配 =
  2. 匹配^~,
  3. 按文件中顺序的正则匹配
  4. / 通用匹配。

当有匹配成功时候,停止匹配,按当前匹配规则处理请求。

假设配置如下:

location = / {
   #规则1
}
location = /api {
   #规则2
}
location ^~ /static/ {
   #规则3
}
location ~ \.(gif|jpg|png|js|css)$ {
   #规则4
}
location ~* \.png$ {
   #规则5
}
location !~ \.xhtml$ {
   #规则6
}
location !~* \.xhtml$ {
   #规则7
}
location / {
   #规则8
}
  1. 当访问根目录 http://localhost/,匹配规则1
  2. 当访问http://localhost/api,匹配规则2
  3. 当访问http://localhost/static/1.png^~会优先匹配规则3
  4. 当访问http://localhost/1.png,匹配规则4,规则5不生效
  5. 当访问http://localhost/1.PNG,匹配规则5,不会匹配规则4,规则5不区分大小写
  6. 当访问http://localhost/a.xhtml 不会匹配规则6和规则7,http://localhost/a.XHTML不会匹配规则7,因为不区分大小写。规则6,规则7属于排除法,符合匹配规则但是不会匹配到
proxy_pass

用于配置反向代理

server {
	listen       80;
	server_name  localhost;

	location / {
		root   html;
		index  index.html index.htm;
		proxy_pass  http://test.com:8080
	}
}

nginx监听 80端口,访问localhost(不加端口号时默认为 80端口)时会跳转到 test.com:8080(本地的话可以通过在host文件上设置ip域名映射) 路径上。

location下,同时配置rootproxy_pass选项时,两个选项只会二选一执行。

uwsgi_pass

wsgi模式下的服务器配置访问方式

location / {
    include uwsgi_params;
    uwsgi_pass localhost:8888
}

upstream

负责负载均衡的配置,通过默认的轮询调度方式来分发请求到后端服务器。

核心配置信息如下:

  • server host:port:分发服务器的列表配置
  • -- down:表示该主机暂停服务
  • -- max_fails:表示失败最大次数,超过失败最大次数暂停服务
  • -- fail_timeout:表示如果请求受理失败,暂停指定的时间之后重新发起请求

nginx的负载均衡模块目前支持4种调度算法:

  • 轮询(默认):每个请求按时间顺序逐一分配到不同的后端服务器,如果后端某台服务器宕机,故障系统被自动剔除,使用户访问不受影响。Weight 指定轮询权值,Weight值越大,分配到的访问机率越高,主要用于后端每个服务器性能不均的情况下。

    按请求时间逐一分配,如果某个服务器挂了,就自动剔除:

    # myserver为自定义的名称
    upstream myserver{
      server 192.168.1.1:80; 
      server 192.168.1.12:8080 max_fails=3 fail_timeout=20s;
      server 192.168.1.123:8080 down;
    }
    

    使用权重:

    upstream myserver{
      server 192.168.1.1:80 weight=5; 
      server 192.168.1.12:8080 weight=10;
    }
    
  • ip_hash:每个请求按访问IPhash结果分配,这样来自同一个IP的访客固定访问一个后端服务器,有效解决了动态网页存在的session共享问题。

    比如说用户A固定ip,第一次访问到192.168.1.1:80,那么后面就都是访问到这台机器

    upstream myserver{
      ip_hash;
      server 192.168.1.1:80; 
      server 192.168.1.12:8080;
    }
    
  • fair:这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。nginx本身是不支持fair的,如果需要使用这种调度算法,必须下载nginxupstream_fair模块。

    upstream myserver{
      server 192.168.1.1:80; 
      server 192.168.1.12:8080;
      fair;
    }
    
  • url_hash:此方法按访问urlhash结果来分配请求,使每个url定向到同一个后端服务器,可以进一步提高后端缓存服务器的效率(同一个资源多次请求,可能会到达不同的服务器上,导致不必要的多次下载,缓存命中率不高,以及一些资源时间的浪费。而使用url_hash,可以使得同一个url(也就是同一个资源请求)会到达同一台服务器,一旦缓存住了资源,再此收到请求,就可以从缓存中读取)。nginx本身是不支持url_hash的,如果需要使用这种调度算法,必须安装nginxhash软件包。

    upstream myserver{
      server 192.168.1.1:80; 
      server 192.168.1.12:8080;
      hash $request_uri;
    }
    
    server {
        listen 8083;
        server_name localhost;
        location /{
      	  proxy_pass http://myserver;
        }
    }
    

注,当负载调度算法为ip_hash时,后端服务器在负载均衡调度中的状态不能是weightbackup

你可能感兴趣的:(nginx,nginx,运维,服务器)