Nginx教程---03.Nginx日志切割
Nginx的定时任务与自动切割
明确:
如果这个网站的访问量比较大,那么一天下来 nginx日志可能会特别的大,所以当出现这种情况呢,如果
把每天的日志都存在同一个日志文件里,会使你的日志文件大到让你怀疑人生,同时也不好管理。所以就
希望每天在一个固定的时间来产生一个新的文件来存储当天的日志,这样就方便管理了很多。
思路:就是使用 定时任务 + USER1信号量来控制Nginx重新生成新的日志文件
此处需要shell脚本(shell脚本只要记住丫的声明就没啥了),与定时任务的相关知识
linux的date命令:
date:查看当前年月日,但不是格式化的,
date -d yesterday : 查看昨天的年月日 是这样形式的 "Fri Apr 13 00:06:06 PDT 2018"
date -d yesterday +'%Y%m%d' : 格式化的昨天的日期,是这样的:20180413 (人类能看懂了)
date -s '2018-4-14 00:09:00' 然后执行 clock -w 命令:修改linux的系统时间
1 开始实现定时任务
① 在/usr/local/nginx/ 下建data文件夹,用于存储每天产生的日志文件
命令:[root@localhost nginx]# mkdir /data
[root@localhost nginx]# cd /data/
[root@localhost data]# vim runlog.sh //建个runlog.sh文件用于写shell脚本的定时任务
我们先来测试一下,写个简单的shell脚本,返回昨天的年月日

使用命令:sh runlog.sh 来执行脚本,查看返回结果

② 正式编辑runlog.sh文件
#!/bin/bash
LOGPATH=/usr/local/nginx/logs/human.com.access.log //nginx产生的日志
BASEPATH=/data/$(date -d yesterday +%Y%m) //每天产生的日志 按照月份 进行存放
mkdir -p $BASEPATH //创建月份文件夹
bak=$BASEPATH/$(date -d yesterday +%d%H%M).human.com.access.log //将每天产生的日志放在对应的月份下
mv $LOGPATH $bak //将nginx产生的日志 剪切 到bak中
touch $LOGPATH //重新创建 human.com.access.log 日志
kill USER1 'cat /usr/local/nginx/logs/nginx.pid' //重复日志
如图:

③ 使用命令 :crontab -e 创建时钟
*/1 * * * * sh /data/runlog.sh
依次:分 时 日 月 周
如图:

以上日志的定时切割准备完毕,下面开始测试:
回到data目录下: 使用ls命令 查看 出现 201804 这个文件夹

进入 2101804 目录下,每隔一分钟执行一次 ls 命令:

OK!定时的日志切割完成,目前为测试方便,定时为一分钟执行一次日志切割,生产环境中可对 定时器 自行设置!
Nginx教程---03.Nginx日志切割的更多相关文章
- Nginx教程(三) Nginx日志管理
Nginx教程(三) Nginx日志管理 1 日志管理 1.1 Nginx日志描述 通过访问日志,你可以得到用户地域来源.跳转来源.使用终端.某个URL访问量等相关信息:通过错误日志,你可以得到系统某 ...
- Nginx教程(三) Nginx日志管理 (转)
Nginx教程(三) Nginx日志管理 1 日志管理 1.1 Nginx日志描述 通过访问日志,你可以得到用户地域来源.跳转来源.使用终端.某个URL访问量等相关信息:通过错误日志,你可以得到系统某 ...
- Nginx 热部署和日志切割,你学会了吗?
上篇文章,我们已经安装好 Nginx,并且配置好 Nginx 文件后,这个时候我就需要操作 Nginx 的命令行了,这篇文章主要讲解 Nginx 命令行相关知识,并通过日常遇到的热部署.切割日志文件场 ...
- Nginx教程(一) Nginx入门教程
Nginx教程(一) Nginx入门教程 1 Nginx入门教程 Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like协议下发行.由 ...
- Nginx教程(二) Nginx虚拟主机配置
Nginx教程(二) Nginx虚拟主机配置 1 虚拟主机管理 1.1 Nginx管理虚拟主机 虚拟主机使用的是特殊的软硬件技术,它把一台运行在因特网上的服务器主机分成一台台“虚拟”的主机,每台虚拟主 ...
- Nginx教程(二) Nginx虚拟主机配置 (转)
Nginx教程(二) Nginx虚拟主机配置 1 虚拟主机管理 1.1 Nginx管理虚拟主机 虚拟主机使用的是特殊的软硬件技术,它把一台运行在因特网上的服务器主机分成一台台“虚拟”的主机,每台虚拟主 ...
- nginx学习(六):日志切割
现有的日志都会存在 access.log 文件中,但是随着时间的推移,这个文件的内容会越来越多,体积会越来越大,不便于运维人员查看,所以我们可以通过把这个大的日志文件切割为多份不同的小文件作为日志,切 ...
- 【09】Nginx:静态压缩 / 日志切割 / 防盗链 /恶意解析/ 跨域
写在前面的话 上一节我们谈了关于 nginx 服务器的一些简单的安全优化问题,能够帮助我们解决一部分线上服务存在的安全隐患.但是想要提升用户体验这是原因不够的,我们还需要从服务的优化方面入手. 本节更 ...
- Nginx 脚本自动进行日志切割
随着网站的运行时间越来越长,日志文件也会随之越来越大需要对Nginx日志进行切割,下面是每周六晚上自动进行日志切割的shell脚本 脚本如下: [root@jrjs ~]# vim /usr/loca ...
随机推荐
- less的写法 calc以及变量
less的文档还是很容易读懂的, 一:结构的嵌套:照着html结构写,目前没有出现错误: 二:变量引用:1,单个变量通常用@变量名 2,多个变量写在一起, 三:calc计算: 目前我觉得最具实用性的就 ...
- Background removal with deep learning
[原文链接] Background removal with deep learning This post describes our work and research on the gree ...
- 通过ALT+F9关键CALL追踪注册码
1)弹出关键字对话框,记录关键字注册失败,请检查···· 2)使用PEID查壳 3)peid提示无壳 4)发送到OD 5)F9使od运行 5.1)继续输入用户 5.2)使其暂停 5.3)点击调试中的执 ...
- IniHelper
/// <summary> /// ini文件操作类 /// </summary> public class IniHelper { #region 动态链接库调用 /// & ...
- svn和NetBeans一起使用造成svn老是死锁, database is locked
其实我一直没发现,又一次我以为需要写些前端吧NetBeans关了,使用HBuilder写vue,因为内存只有8G,乱七八糟的一些东西一开,只剩20%左右,我就把 NetBeans关了,发现更新svn的 ...
- spark-sql(spark sql cli)客户端集成hive
1.安装hadoop集群 参考:http://www.cnblogs.com/wcwen1990/p/6739151.html 2.安装hive 参考:http://www.cnblogs.com/w ...
- J2EE快速开发框架
地址: http://git.oschina.net/blind/app 项目简介 使用Maven对项目进行模块化管理,提高项目的易开发性.扩展性. 实现了通用的系统管理模块功能,包含:用户.角色.权 ...
- 一招制敌 - 玩转 AngularJS 指令的 Scope (作用域),讲得特别好
学习了AngularJS挺长时间,最近再次回首看看指令这部分的时候,觉得比自己刚开始学习的时候理解的更加深入了,尤其是指令的作用域这部分. 步入正题: 每当一个指令被创建的时候,都会有这样一个选择,是 ...
- Cestos7安装Elasticsearch5.4.3
Elasticsearch及配件下载地址:https://www.elastic.co/cn/downloads 为了简单起见,我们使用tar文件. 在/usl下创建elk目录 一.安装elastic ...
- python框架之Django(7)-Cookie&Session使用
Cookie 添加 response.set_cookie 添加明文cookie response.set_cookie(key, value='', max_age=None, expires=No ...