Nginx日志切割 手动+定时两种方式 非常详细
2023-09-11 14:21:24 时间
注意:首先要先保证nginx处于启动的状态!!
然后写我们脚本文件cut_my_log.sh:
#!/bin/bash
LOG_PATH="/var/log/nginx"
RECORD_TIME=$(date -d "now" +%Y-%m-%d+%H:%M)
PID=/var/run/nginx/nginx.pid
mv ${LOG_PATH}/access.log ${LOG_PATH}/access.${RECORD_TIME}.log
mv ${LOG_PATH}/error.log ${LOG_PATH}/error.${RECORD_TIME}.log
#向Nginx主进程发送信号,用于重新打开日志文件
kill -USR1 `cat $PID`
这边我是把写好的脚本文件放在了 /usr/local/nginx/sbin 目录下:
手动方式:
执行我们写好的脚本文件~
如果有出现权限不够的情况,记得先给脚本文件增加可执行权限:
添加可执行权限:
然后执行脚本文件:
执行完后可以发现我们日志文件已经切割完成了:
定时方式
1.先安装定时任务依赖:
yum install crontabs
2.终端输入命令:crontab -e 添加一行新的定时任务(每分钟执行一次日志切割):
*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh
添加完记得输入 :wq 保存并退出。
然后输入crontab -l 命令能看到我们刚才添加的定时任务:
3.添加完后我们要重新启动下我们的定时任务:
service crond restart
可以看到我们的日志定时每分钟切割一次:
附录
常用定时任务命令:
命令 | 解释 |
---|---|
service crond start | 启动服务 |
service crond stop | 关闭服务 |
service crond restart | 重启服务 |
service crond reload | 重新载入配置 |
crontab -e | 编辑任务 |
crontab -l | 查看任务列表 |
Cron表达式:
分 | 时 | 日 | 月 | 星期几 | 年(可选) | |
---|---|---|---|---|---|---|
取值范围 | 0-59 | 0-23 | 1-31 | 1-12 | 1-7 | 2019/2020/2021/… |
常用表达式:
- 每分钟执行
*/1 * * * *
- 每天晚上23:59执行
59 23 * * *
- 每日凌晨1点执行
0 1 * * *
相关文章
- nginx重新整理——————http请求的11个阶段中的日志阶段[十九]
- linux(centos8):用apache的rotatelogs做nohup的日志切分
- 日志查看审计程序
- 创建并写入自定义日志信息
- MySQL内核月报 2015.02-TokuDB · 特性分析· 日志详解
- Nginx日志过滤 使用ngx_log_if不记录特定日志
- Nginx正确记录post日志的方法
- ELK详解(十三)——Logstash收集Nginx日志实战
- Prometheus nginx-vts-exporter 监控 Nginx
- Logstash+Redis+Elasticsearch+Kibana+Nginx搭建日志分析系统
- 点击终端打印日志
- Java Logger(java日志)
- nginx为例的日志切割处理方式——筑梦之路
- Dubbo添加过滤器(二)---日志打印接口耗时
- 真香,Grafana开源Loki日志系统取代ELK?
- 向HIVE导入windows平台(dos类型)的日志
- Linux Apache/Nginx 日志统计命令
- Shell if语句实现mysqldump全量备份+mysqlbinlog二进制日志增量备份