向nginx发送reopen信号以重新打开日志文件

Posted 缤纷世界WB

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了向nginx发送reopen信号以重新打开日志文件相关的知识,希望对你有一定的参考价值。

先移动日志文件

mv /usr/local/openresty/nginx/logs/access.log /usr/local/openresty/nginx/logs/access.log.20161024

发送信号重新打开日志文件

kill -USR1 $(cat /usr/local/openresty/nginx/logs/nginx.pid)

简单说明一下:

1、在没有执行kill -USR1 `cat ${pid_path}`之前,即便已经对文件执行了mv命令也只是改变了文件的名称,nginx还是会向新命名的文件” access.log.20161024”中照常写入日志数据。原因在于linux系统中,内核是根据文件描述符来找文件的

2、USR1是自定义信号,也就是进程编写者自己确定收到这个信号该干什么。而在nginx中它自己编写了代码当接到USR1信号的时候让nginx重新打开日志文件(重新打开的日志就是配置文件中设置的位置和名称)

以上是关于向nginx发送reopen信号以重新打开日志文件的主要内容,如果未能解决你的问题,请参考以下文章

Nginx命令行及演示:重载热部署日志切割

nginx常用命令参数

nginx常用语句

4. nginx命令行

03-nginx虚拟主机配置

Linux nginx日志按天分割实例