Nginx日志切割
由于 Nginx 的日志(包括 access
和 error
)默认都是存放在一个文件夹内,当时间长了,日志文件体积越来越大,不易管理,可以自己写个脚本来处理,其实就是定时定点去把日志移动下位置。
1 | !/bin/sh |
有几个注意的:
- 日志源目录 - 该目录存放日志文件,如
access.log
,error.log
,当然如果你的站点比较多,可以用域名来命名,比如:jeremy.com.access.log
,jeremy.com.error.log
。 - 日志备份目录 - 会以
Ymd
命名文件夹名存放在该目录。 - 刷新 Nginx - 由于是直接移动日志文件,移动后需要刷新下 Nginx 使其再生成日志文件,当然也可以
nginx -s reload
,但 reload 要比 kill 的慢,而kill -USR1
是无损的。 - 定时任务 - 需要使用 root 帐户下使用
crontab -e
插入一条定时任务,定时 23:55 开始分割,后面是把错误和信息输出到指定文件,方便调试,如:
1 | 55 23 * * * sh /你的目录/split-log >> /var/log/nginx/crontab.log 2>&1 |
当然这只是日志切割的一种,还有很多种方法~ 你也可以按照自己的想法编写脚本。
欢迎关注我的公众号 须弥零一,跟我一起学习IT知识。
如果您喜欢此博客或发现它对您有用,则欢迎对此发表评论。 也欢迎您共享此博客,以便更多人可以参与。 如果博客中使用的图像侵犯了您的版权,请与作者联系以将其删除。 谢谢 !