nginx.conf
1 | # 定义Nginx运行的用户和用户组。window下不指定 |
日志
日志级别如下:
1 | ngx.STDERR -- 标准输出 |
修改nginx.conf文件中
1 | error_log /var/log/ngingx/error.log warn |
然后在Lua脚本中调用
1 | ngx.log(ngx.WARN,string.format("")) |
日志输出如下:
1 | 2017/06/06 19:32:26 [warn] 19356#3272: *20 [lua] content_by_lua(nginx.conf:52):5: [WARN] The request is from 127.0.0.1, client: 127.0.0.1, server: , request: "GET / HTTP/1.1", host: "localhost" |
第一行为warn级别,第二行为error级别,第三行为Access日志。
系统中可以将关键流程日志设置为Warn,而非Notice和Info,因为nginx本身会输出大量的Notice和info信息。
location 匹配规则
语法规则
1 | location [=|~|~*|^~] /uri/ { … } |
模式 | 含义 |
---|---|
location = /uri |
= 表示精确匹配,只有完全匹配上才能生效 |
location ^~ /uri |
^~ 开头对URL路径进行前缀匹配,并且在正则之前。 |
location ~ pattern |
开头表示区分大小写的正则匹配 |
location ~* pattern |
开头表示不区分大小写的正则匹配 |
location /uri |
不带任何修饰符,也表示前缀匹配,但是在正则匹配之后 |
location / |
通用匹配,任何未匹配到其它location的请求都会匹配到,相当于switch中的default |
前缀匹配时,Nginx 不对 url 做编码,因此请求为 /static/20%/aa,可以被规则 ^~ /static/ /aa 匹配到(注意是空格)
多个 location 配置的情况下匹配顺序为
- 首先精确匹配 =
- 其次前缀匹配 ^~
- 其次是按文件中顺序的正则匹配
- 然后匹配不带任何修饰的前缀匹配。
- 最后是交给 / 通用匹配
- 当有匹配成功时候,停止匹配,按当前匹配规则处理请求
注意:前缀匹配,如果有包含关系时,按最大匹配原则进行匹配。比如在前缀匹配:location /dir01
与 location /dir01/dir02
,如有请求 http://localhost/dir01/dir02/file
将最终匹配到 location /dir01/dir02