Nginx日志切分

nginx日志如果不切分,会导致access.log一直很大,如果开启了debug 输出request_body日志会刷的特别快,很可能很快达到几十个G,配置低的服务器可能磁盘就100%了,接口504 game over了,所以对于nginx的access和error日志都需要做每天的日志切分,对于历史日志做定期清理。
(1)在/etc/logrotate.d目录下增加nginx配置文件

cd /ec/logrotate.d

vim nginx

添加如下内容:

bash 复制代码
#具体nginx日志路径依项目而定
/usr/local/nginx/nginx-1.16.1/logs/*.log {
        daily  # 轮转频率:每天
        missingok   # 如果日志不存在,不报错
        rotate 14   # 保留14个旧日志文件
        compress  # 压缩旧日志(gzip)
        delaycompress  # 延迟压缩(下一个周期压缩)
        notifempty  # 空日志不轮转
        create 646 nginx adm  # 创建新日志的权限和所有者
        sharedscripts  # 所有日志处理完再执行脚本
        postrotate
        nginx -s reload  #重启nginx
        endscript
}

/etc/logrotate.d/Linux 系统中管理日志轮转的核心目录。

  • 位置/etc/logrotate.d/ 是 logrotate 服务的配置目录

  • 主配置/etc/logrotate.conf 是全局配置文件

  • 子配置/etc/logrotate.d/ 包含各个应用程序的独立配置文件

  • 用途:自动管理日志文件,防止日志过大占满磁盘

1. 轮转频率

bash

复制代码
daily         # 每天轮转
weekly        # 每周轮转
monthly       # 每月轮转
size 100M     # 大小达到100M时轮转

2. 保留策略

bash

复制代码
rotate 7      # 保留7个旧日志文件
maxage 30     # 删除超过30天的日志
maxsize 100M  # 单个日志最大100M

3. 压缩设置

bash

复制代码
compress              # 使用gzip压缩
nocompress            # 不压缩
compresscmd /bin/bzip2 # 指定压缩工具
compressext .bz2      # 指定扩展名
delaycompress         # 延迟一个周期压缩

4. 文件处理

bash

复制代码
create 0640 user group  # 创建新日志的权限
copytruncate            # 复制后清空(不需要重启服务)
nocreate                # 不创建新日志
dateext                 # 使用日期作为后缀
dateformat .%Y%m%d      # 日期格式

5. 脚本钩子

bash

复制代码
prerotate
    # 轮转前执行的命令
endscript

postrotate
    # 轮转后执行的命令(如重启服务)
endscript

firstaction
    # 第一次轮转时执行
endscript

(2)添加定期清理日志的crontab定时任务

crontab -e 编辑定时任务,添加如下命令

bash 复制代码
0  1 * * * /usr/bin/find /usr/local/nginx/nginx-1.16.1/logs/ -name "*.gz" -mtime +5  | xargs -i /usr/bin/rm -irf {}
相关推荐
mixuecoding几秒前
零成本搭建全球科技热点情报站:12 个平台,6 小时,0 元
前端
用户059540174466 分钟前
用了3年Mock,才发现Redis记忆存储的测试一直漏掉了60%的边界场景
前端·css
石小石Orz7 分钟前
AI具身交互:实现一个会说话的3D虚拟伴侣
前端·人工智能·后端
Muen24 分钟前
iOS设计模式-外观Facade
前端
Cobyte1 小时前
21.Vue Vapor 组件的实现原理
前端·javascript·vue.js
前端双越老师1 小时前
我从 0 开发的 AI Agent 智语项目发布了
前端·node.js·agent
橙某人1 小时前
LogicFlow 工作流撤销与重做:从「全量快照」到「命令模式」🎯
前端·vue.js
铁皮饭盒1 小时前
Rust版Bun1.4之前, 盘点Bun1.3新特性
前端·javascript·后端
恋猫de小郭1 小时前
如何让 AI 快速搭建一套生产 Agent ?全面理解 Agent 架构。
前端·人工智能·ai编程