Nginx——模块(1)

nginx的模块

nginx高度模块化,但其模块早期不支持DSO机制;1.9.11版本支持动态装载和卸载

核心模块:core module

标准模块:

  • HTTP 模块:ngx_http_*
  • Mail 模块 ngx_mail_*
  • Stream 模块 ngx_stream_*

第三方模块:

ngx_http_core_module 核心模块

1)server { ... }:配置虚拟主机

 # vim /etc/nginx/nginx.conf
 http  { 
    server {
        listen 80;
        server_name www.miaosen.tech;
        root /data/www/;
    }
    server {
        listen 80;
        server_name news.miaosen.tech;
        root /data/news/;
    }
}
# nginx  启动服务
# echo news site > /data/news/index.html
# echo www site > /data/www/index.html

  

客户端测试:

# curl www.miaosen.tech
www site
# curl news.miaosen.tech
news site

  

2)listen port|address[:port]|unix:/PATH/TO/SOCKET_FILE

listen address[:port] [default_server] [ssl] [http2 | spdy]  [backlog=number] [rcvbuf=size] [sndbuf=size]

  

  • default_server:设定为默认虚拟主机
  • ssl:限制仅能够通过ssl连接提供服务
  • backlog=number:超过并发连接数后,新请求进入后援队列的长
  • rcvbuf=size:接收缓冲区大小
  • sndbuf=size:发送缓冲区大小

listen PORT; 指令监听在不同的端口,可实现基于端口的虚拟主机

listen IP:PORT; 监听 IP 地址不同,实现基于IP的虚拟主机

3)server_name name ...

虚拟主机的主机名称后可跟多个由空白字符分隔的字符串

支持*通配任意长度的任意字符

    server {
        listen 80;
        server_name *.miaosen.tech;
        root /data/default/;
    }
# echo default > /data/default/index.html
# nginx -s reload
# curl xxx.miaosen.tech
default

  

支持 ~ 起始的字符做正则表达式模式匹配,性能原因慎用

server_name     ~^www\d+\.miaosen\.tech$  #说明:\d 表示 [0-9]

  

匹配优先级机制从高到低:

(1) 首先是字符串精确匹配 如:www.miaosen.com

(2) 左侧*通配符 如:*.miaosen.tech

(3) 右侧*通配符 如:www.miaosen.*

(4) 正则表达式 如: ~^.*\.miaosen\.tech$

(5) default_server

4)tcp_nodelay on|off

在keepalived模式下的连接是否启用TCP_NODELAY选项

当为off时,延迟发送,合并多个请求后再发送

默认on时,不延迟发送

可用于:http, server, location

如果为了节约服务器性能可以打开,如果为了用户体验更好选择关闭

5)sendfile on|off

是否启用sendfile功能,在内核中封装报文直接发送,默认关闭

6)server_tokens on|off|build|string

是否在响应报文的Server首部显示nginx版本,建议关闭

7)root

设置web资源的路径映射;用于指明请求的URL所对应的文档的目录路径,可用于http, server, location, if in location

8)location [ = | ~ | ~* | ^~ ] uri { ... }

在一个server中location配置段可存在多个,用于实现从uri到文件系统的路径映射;ngnix会根据用户请求的URI来检查定义的所有location,并找出一个最佳匹配,而后应用其配置

# mkdir /data/www/blog/
# echo blog > /data/www/blog/index.html
# vim /etc/nginx/nginx.conf
    server {
        listen 80;
        server_name www.miaosen.tech;
        root /data/www/;
        location /blog {
            root /data/www/;
        }
    }
# curl http://www.miaosen.tech/blog/  #测试
blog

  

=:对URI做精确匹配

^~: 对URI的最左边部分做匹配检查,不区分字符大小写

~: 对URI做正则表达式模式匹配,区分字符大小写

~*: 对URI做正则表达式模式匹配,不区分字符大小写

不带符号:匹配起始于此uri的所有的uri

匹配优先级从高到低:=, ^~, ~/~*, 不带符号

例如:

location = / {
    [ configuration A ]
}
location / {
    [ configuration B ]
}
location /documents/ {
    [ configuration C ]
}
location ^~ /images/ {
    [ configuration D ]
}
location ~* \.(gif|jpg|jpeg)$ {
    [ configuration E ]
}

  

The “/” request will match configuration A, 
the “/index.html” request will match configuration B, 
the “/documents/document.html” request will match configuration C, 
the “/images/1.gif” request will match configuration D, 
and the “/documents/1.jpg” request will match configuration E.

  

9)alias

路径别名,文档映射的另一种机制;仅能用于location上下文

    server {
        listen 80;
        server_name www.miaosen.tech;
        root /data/www/;
        location /blog;
            alias /data/www/blog;  #和root /data/www/;作用相同
        }
    }
# curl http://www.miaosen.tech/blog/
blog

  

注意:location中使用root指令和alias指令的意义不同

(a) root,给定的路径对应于location中的/uri/左侧的/

(b) alias,给定的路径对应于location中的/uri/右侧的/

10)index file ...

指定默认网页文件,注意需要装载 ngx_http_index_module 模块

11)error_page code ... [=[response]] uri

定义错误页,以指定的响应状态码进行响应;可用位置:http, server, location, if in location

# echo "404 not found page" > /data/www/404.html
    server {
        listen 80;
        server_name www.miaosen.tech;
        root /data/www/;
        error_page 404 /404.html;
    }
# curl http://www.miaosen.tech/notfound.html
404 not found page
    server {
        listen 80;
        server_name www.miaosen.tech;
        root /data/www/;
        error_page 404 =200 /404.html;  #将404返回码重定向成200访问码,防止浏览器劫持
    }
# curl -I http://www.miaosen.tech/notfound.html
HTTP/1.1 200 OK  #测试为200正确访问码

  

12)try_files file ... uri | =code

​ 按顺序检查文件是否存在,返回第一个找到的文件或文件夹(结尾加斜线表示为文件夹),如果所有的文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。只有最后一个参数可以引起一个内部重定向,之前的参数只设置内部URI的指向。最后一个参数是回退URI且必须存在,否则会出现内部500错误

# echo default page > /data/news/default.html
    server {
        listen 80;
        server_name news.miaosen.tech;
        root /data/news/;
        location / {
            try_files $uri /default.html;  #如果用户访问的URI不存在则放回默认页面
        }
    }
# curl http://news.miaosen.tech/index.html   
news site
# curl http://news.miaosen.tech/noindex.html
default page
    server {
        listen 80;
        server_name news.miaosen.tech;
        root /data/news/;
        location / {
            try_files $uri $uri/index.html $uri.html =404;
        }
    }
# curl http://news.miaosen.tech/index.html  
news site
# curl http://news.miaosen.tech/noindex.html
404 Not Found

  

13)keepalive_timeout timeout [header_timeout]

设定保持连接超时时长,0表示禁止长连接,默认为75s,可用于http, server, location

14)keepalive_requests number

在一次长连接上所允许请求的资源的最大数量,默认为100

15)keepalive_disable none | browser ...

对哪类型的浏览器禁用长连接

16)send_timeout time

向客户端发送响应报文的超时时长,此处是指两次写操作之间的间隔时长,而非整个响应过程的传输时长

17)client_body_buffer_size size

用于接收每个客户端请求报文的body部分的缓冲区大小;默认为16k;

超出此大小时,其将被暂存到磁盘上的由下面 client_body_temp_path 指令所定义的位置

18)client_body_temp_path path [level1 [level2 [level3]]]

设定存储客户端请求报文的body部分的临时存储路径及子目录结构和数量

19)limit_rate rate

限制响应给客户端的传输速率,单位是bytes/second;默认值0表示无限制

20)limit_except method ... { ... }

限制客户端使用除了指定的请求方法之外的其它方法,仅用于location

method:GET(包括HEAD), HEAD, POST, PUT, DELETE, MKCOL, COPY, MOVE, OPTIONS, PROPFIND, PROPPATCH, LOCK, UNLOCK, PATCH

location /upload {
    root /date/www/;
    limit_except GAT {
        allow 192.168.0.9/24;
        deny all;
    }
}
# 除了 GET和HEAD 之外其它方法仅允许192.168.0.9/24主机使用

  

21)aio on | off | threads[=pool]

是否启用aio功能

22)directio size | off

当文件大于等于给定大小时,例如directio 4m,同步到磁盘,而非写缓存,以防数据丢失

23)open_file_cache off | max=N [inactive=time]

  • max=N:可缓存的缓存项上限;达到上限后会使用LRU算法实现管理
  • inactive=time:缓存项的非活动时长,在此处指定的时长内未被命中的或命中的次数少于open_file_cache_min_uses指令所指定的次数的缓存项即为非活动项将被删除

24)open_file_cache_errors on | off

是否缓存查找时发生错误的文件一类的信息,默认值为off

25)open_file_cache_min_uses number

open_file_cache指令的inactive参数指定的时长内,至少被命中此处指定的次数方可被归类为活动项,默认值为1

26)open_file_cache_valid time

缓存项有效性的检查频率,默认值为60s

posted @ 2018-07-29 16:54  Gmiao  阅读(252)  评论(0编辑  收藏  举报