Nginx定时日志切割


现有的日志都会存在access.log文件中,但是随着时间的推移,这个文件的内容会越来越多,体积会越来越大,不便于运维 人员查看,所以我们可以通过把这个大的日志文件切割为多份不 同的小文件作为日志,切割规则可以以天为单位,如果每天有几 百G或者几个T的日志的话,则可以按需以每半天或者每小时对曰志切割一下。


具体步骤如下:

1.创建一shell可执行文件:cut_my_log.sh,内容为:

#!/bin/bash
LOG_PATH="/var/log/nginx/"
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
PID=/va r/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
#进程发送信号,用于重开打开日志文件
kill -USR1 'cat $PID'
  1. 为cut_my_log.sh添加可执行的权限:
chmod +x cut_my_log.sh
  1. 测试日志切割后的结果:
./cut_my_log.sh

4.安装定时任务

yum install crontabs

5.crontab -e编辑并且添加一行新的任务

(定时任务使用cron表达式)

*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh

6.重启定时任务:

service crond restart
  • 常用定时任务命令:
命令 说明
service crond start 启动服务
service crond stop 关闭服务
service crond restart 重启服务
service crond reload 重新载入配置
crontab -e 编辑任务
crontab -1 查看任务列表

最新文章

  1. [vijos1907][NOIP2014]飞扬的小鸟
  2. 使用Gradle自动发布Java Web到SAE
  3. Android TextUtils类介绍
  4. memcached缓存知识简单梳理
  5. 使用C语言实现二维,三维绘图算法(2)-解析曲面的显示
  6. uboot的mkconfig分析
  7. 在world2013中插入GB_2312
  8. 改进《完美让IE兼容input placeholder属性的jquery实现》的不完美
  9. Linux下core文件产生的一些注意问题
  10. swift 2.0 与 OC 相比较,标签栏和导航栏书写的差别
  11. 数据库备份shell脚本
  12. 自反ACL(第三组)
  13. CASE WHEN 高阶用法?
  14. C#中的yield return用法演示源码
  15. weblogic8控制台禁止(允许)访问配置方法
  16. CF1139D Steps to One(DP,莫比乌斯反演,质因数分解)
  17. MYSQL InnoDB Cluster
  18. Django开发笔记六
  19. [uboot]uboot中run的一些command在源码位置
  20. MyBatis返回插入的主键ID(Mysql数据库)

热门文章

  1. css导航菜单二级显示的问题
  2. eclipse导入项目出现红叉
  3. 记IntelliJ IDEA创建spring mvc一次坑爹的操作!!!!
  4. Monster Audio 使用教程(四)Wifi 远程遥控
  5. python-多任务编程01-线程(threading)
  6. js 绑定的键盘事件
  7. ffmpeg获取视频封面图片
  8. 一个简单的Android小实例分享,包含recycleView与recyclerView嵌套
  9. Django坑_01
  10. java反序列化——apache-shiro复现分析