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 {}
相关推荐
齐落山大勇11 小时前
Linux的文件IO
linux·运维·服务器
七七powerful11 小时前
运维养龙虾--Tmux 终端复用器完全指南:从入门到 AI Agent 远程操控
运维·服务器·人工智能
tod11311 小时前
深入解析ext2文件系统架构
linux·服务器·c++·文件系统·ext
m0_6948455712 小时前
CRUD (Nestjsx)部署教程:自动生成RESTful接口
服务器·人工智能·后端·开源·自动化·restful
萧行之12 小时前
FRP 0.62.0 + Mac Ollama 公网穿透部署+排障实录(标准 TOML 格式)
linux·服务器
心连欣12 小时前
解锁对象遍历:当字符串遇上for...in循环
前端·javascript
Sestid12 小时前
前端Cursor使用指南(后续会更新Claude)
前端·claude·cursor
戴维南12 小时前
LangChain 在 Agent 开发中的定位:10 个模块(含代码对比,耳机售后案例)
前端
ouzz12 小时前
使用纯canvas绘制一个掘金首页
前端·canvas
添砖java‘’12 小时前
数据链路层
服务器·网络·数据链路层