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 {}
相关推荐
mldlds13 小时前
windows手动配置IP地址与DNS服务器以及netsh端口转发
服务器·windows·tcp/ip
毛骗导演13 小时前
@tencent-weixin/openclaw-weixin 插件深度解析(四):API 协议与数据流设计
前端·架构
毛骗导演13 小时前
@tencent-weixin/openclaw-weixin 插件深度解析(二):消息处理系统架构
前端·架构
IT_陈寒13 小时前
深入理解JavaScript:核心原理与最佳实践
前端·人工智能·后端
MrGud13 小时前
Cesium中的坐标系及其转换
前端·cesium
小付学代码13 小时前
香港地图可编辑版
前端
兆子龙13 小时前
TypeScript高级类型编程:从入门到精通
前端·后端
SuperEugene13 小时前
Vue3 模板语法规范实战:v-if/v-for 不混用 + 表达式精简,避坑指南|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
一直都在57213 小时前
深入理解 synchronized:到底锁的是谁?
运维·服务器
IT_陈寒14 小时前
Python开发者的效率革命:这5个技巧让你的代码提速50%!
前端·人工智能·后端