0
点赞
收藏
分享

微信扫一扫

nginxd打印日志


如何打开nginx rewrite log

nginx通过ngx_http_rewrite_module模块支持url重写、支持if条件判断,但不支持else。

该模块需要PCRE支持,应在编译nginx时指定PCRE源码目录,nginx安装方法。

nginxrewrite指令执行顺序:

1.执行server块的rewrite指令(这里的块指的是server关键字后{}包围的区域,其它xx块类似)

2.执行location匹配

3.执行选定的location中的rewrite指令

如果其中某步URI被重写,则重新循环执行1-3,直到找到真实存在的文件

如果循环超过10次,则返回500InternalServerError错误

break指令

语法:break;

默认值:无

作用域:server,location,if

停止执行当前虚拟主机的后续rewrite指令集

break指令实例:

if($slow){

limit_rate10k;

break;

语法:if(condition){...}

默认值:无

作用域:server,location

对给定的条件condition进行判断。如果为真,大括号内的rewrite指令将被执行。

if条件(conditon)可以是如下任何内容:

一个变量名;false如果这个变量是空字符串或者以0开始的字符串;

使用=,!=比较的一个变量和字符串

是用~,~*与正则表达式匹配的变量,如果这个正则表达式中包含},;则整个表达式需要用"或'包围

使用-f,!-f检查一个文件是否存在

使用-d,!-d检查一个目录是否存在

使用-e,!-e检查一个文件、目录、符号链接是否存在

使用-x,!-x检查一个文件是否可执行

if指令实例

if($http_user_agent~MSIE){

rewrite^(.*)$/msie/$1break;

if($http_cookie~*"id=([^;]+)(?:;|$)"){

set$id$1;

if($request_method=POST){

return405;

if($slow){

limit_rate10k;

if($invalid_referer){

return403;

return指令

语法:returncode;

returncodeURL;

returnURL;

默认值:无

作用域:server,location,if

停止处理并返回指定状态码(code)给客户端。

非标准状态码444表示关闭连接且不给客户端发响应头。

从0.8.42版本起,return支持响应URL重定向(对于301,302,303,307),或者文本响应(对于其他状态码).

对于文本或者URL重定向可以包含变量

rewrite指令

语法:rewriteregexreplacement[flag];

默认值:无

作用域:server,location,if

如果一个URI匹配指定的正则表达式regex,URI就按照replacement重写。

rewrite按配置文件中出现的顺序执行。flags标志可以停止继续处理。

如果replacement以"http://"或"https://"开始,将不再继续处理,这个重定向将返回给客户端。

flag可以是如下参数

last停止处理后续rewrite指令集,然后对当前重写的新URI在rewrite指令集上重新查找。

break停止处理后续rewrite指令集,并不在重新查找,但是当前location内剩余非rewrite语句和location外的的非rewrite语句可以执行。

redirect如果replacement不是以http://或https://开始,返回302临时重定向

permant返回301永久重定向

最终完整的重定向URL包括请求scheme(http://,https://等),请求的server_name_in_redirect和port_in_redirec三部分,说白了也就是http协议域名端口三部分组成。

rewrite实例

server{

rewrite^(/download/.*)/media/(.*)\..*$$1/mp3/$2.mp3last;

rewrite^(/download/.*)/audio/(.*)\..*$$1/mp3/$2.ralast;

return403;

如果这些rewrite放到“/download/”location如下所示,那么应使用break而不是last,使用last将循环10次匹配,然后返回500错误:

location/download/{

rewrite^(/download/.*)/media/(.*)\..*$$1/mp3/$2.mp3break;

rewrite^(/download/.*)/audio/(.*)\..*$$1/mp3/$2.rabreak;

return403;

对于重写后的URL(replacement)包含原请求的请求参数,原URL的?后的内容。如果不想带原请求的参数,可以在replacement后加一个问号。如下,我们加了一个自定义的参数user=$1,然后在结尾处放了一个问号?,把原请的参数去掉。

rewrite^/users/(.*)$/show?user=$1?last;

如果正则表达regex式中包含“}”或“;”,那么整个表达式需要用双引号或单引号包围.

rewrite_log指令

语法:rewrite_logon|off;

默认值:rewrite_logoff;

作用域:http,server,location,if

开启或关闭以notice级别打印rewrite处理日志到errorlog文件。

nginx打开rewritelog例子

rewrite_logon;

error_loglogs/xxx.error.lognotice;

1.打开rewriteon

2.把errorlog的级别调整到notice

set指令

语法:setvariablevalue;

默认值:none

作用域:server,location,if

定义一个变量并赋值,值可以是文本,变量或者文本变量混合体。

uninitialized_variable_warn指令

语法:uninitialized_variable_warnon|off;

默认值:uninitialized_variable_warnon

作用域:http,server,location,if

控制是否输出为初始化的变量到日志

大量NGINX日志怎么存

写个脚本,做个任务计划,每天或每小时归档一次复制脚本到root目录下nginxLogRotate.sh(自己创建)#!/bin/bashLOGS_PATH=/usr/local/nginx/logsYESTERDAY=$(date -d "yesterday" +%Y-%m-%d)mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.logmv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log## 向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)crontab -e23 59 */1 * * root /usr/local/nginx/logs/nginxLogRotate.sh

举报

相关推荐

0 条评论