nginx日志切割脚本 —— 筑梦之路

2024-04-16 06:36

本文主要是介绍nginx日志切割脚本 —— 筑梦之路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#!/bin/bash  # 定义Nginx日志目录  
LOG_DIR=/www/server/nginx/logs  # 获取上一天的时间,格式为YYYY-MM-DD  
YESTERDAY_TIME=$(date -d "yesterday" +%F)  # 归档日志的目录,按月创建,如2023-10  
LOG_MONTH_DIR=$LOG_DIR/$(date +"%Y-%m")  # 定义需要切割的日志文件名称列表,这里以access.log为例  
LOG_FILE_LIST="access.log"  # 循环处理日志文件  
for LOG_FILE in $LOG_FILE_LIST; do  # 如果归档目录不存在,则创建该目录  [ ! -d $LOG_MONTH_DIR ] && mkdir -p $LOG_MONTH_DIR  # 将日志文件移动到归档目录,并在文件名后加上上一天的时间戳  mv $LOG_DIR/$LOG_FILE $LOG_MONTH_DIR/${LOG_FILE}_${YESTERDAY_TIME}  
done  # 发送USR1信号给Nginx进程,使其重新打开日志文件  
kill -USR1 $(cat $LOG_DIR/nginx.pid)
  1. 定义日志目录和需要切割的日志文件:脚本首先定义了Nginx的日志目录LOG_DIR和需要切割的日志文件名称列表LOG_FILE_LIST。在这个例子中,我们只处理了access.log,但你可以根据需要添加更多的日志文件,如error.log等。

  2. 获取上一天的时间:使用date命令获取上一天的时间,并格式化为YYYY-MM-DD的形式,存储在变量YESTERDAY_TIME中。

  3. 创建归档日志目录:按月创建归档日志的目录,目录名称为当前年月,如2023-10。如果该目录不存在,则使用mkdir -p命令创建它。

  4. 切割并归档日志文件:通过循环处理日志文件列表中的每一个文件。对于每个文件,我们将其移动到归档目录,并在文件名后加上上一天的时间戳,以便于区分和管理。

  5. 重新打开日志文件:最后,我们通过发送USR1信号给Nginx进程来通知其重新打开日志文件。Nginx在接收到USR1信号后,会关闭当前的日志文件并打开新的日志文件进行记录。这样,我们就可以实现日志文件的自动切割和归档了。

你可以将上述脚本保存为一个.sh文件,比如cut_nginx_logs.sh,并赋予其执行权限(chmod +x cut_nginx_logs.sh)。然后,你可以通过cron定时任务来定期执行这个脚本,以实现日志的自动切割和归档。

此外,你还可以根据需要对脚本进行定制。例如,你可以修改LOG_DIRLOG_FILE_LIST变量来适应你的实际环境。你也可以修改归档目录的命名规则和日志文件的命名规则,以满足你的特定需求。

 

这篇关于nginx日志切割脚本 —— 筑梦之路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/908034

相关文章

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

我在移动打工的日志

客户:给我搞一下录音 我:不会。不在服务范围。 客户:是不想吧 我:笑嘻嘻(气笑) 客户:小姑娘明明会,却欺负老人 我:笑嘻嘻 客户:那我交话费 我:手机号 客户:给我搞录音 我:不会。不懂。没搞过。 客户:那我交话费 我:手机号。这是电信的啊!!我这是中国移动!! 客户:我不管,我要充话费,充话费是你们的 我:可是这是移动!!中国移动!! 客户:我这是手机号 我:那又如何,这是移动!你是电信!!

centos6一键安装vsftpd脚本

centos6一键安装vsftpd脚本 手动安装vsftpd参考教程:Centos下安装Vsftpd的图文教程 vsftpd脚本功能: 1.安装 (命令执行:sh xxx.sh)2.添加ftp用户 (命令执行:sh xxx.sh add)3.卸载vsftpd (命令执行:sh xxx.sh uninstall) 测试环境:centos6 x64 centos6 x86(测试centos7以

Windows下Nginx的安装及开机启动

1、将nginx-1.16.1.zip解压拷贝至D:\web\nginx目录下。 2、启动Nginx,两种方法: (1)直接双击nginx.exe,双击后一个黑色的弹窗一闪而过。 (2)打开cmd命令窗口,切换到nginx目录下,输入命令 nginx.exe 或者 start nginx ,回车即可。 3、检查nginx是否启动成功。 直接在浏览器地址栏输入网址 http://lo

nginx介绍及常用功能

什么是nginx nginx跟Apache一样,是一个web服务器(网站服务器),通过HTTP协议提供各种网络服务。 Apache:重量级的,不支持高并发的服务器。在Apache上运行数以万计的并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。这些都决定了Apache不可能成为高性能WEB服务器  nginx:

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

nginx长连接的问题

转自: http://www.360doc.com/content/12/1108/17/1073512_246644318.shtml

NGINX轻松管理10万长连接 --- 基于2GB内存的CentOS 6.5 x86-64

转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=190176&id=4234854 一 前言 当管理大量连接时,特别是只有少量活跃连接,NGINX有比较好的CPU和RAM利用率,如今是多终端保持在线的时代,更能让NGINX发挥这个优点。本文做一个简单测试,NGINX在一个普通PC虚拟机上维护100k的HTTP

CRtmpServer转推流到Nginx Rtmp及SRS(SimpleRtmpServer)的经历

转自:http://blog.csdn.net/fengyily/article/details/42557841 本人一直用的是CRtmpServer服务,在CRtmpServer服务中根据自已的想法也加入了许多功能,如通过http接口来加载配置等,苦于不支持HLS,自已添加ts分片水平又有限,思来想去决定借助SimpleRtmpServer的HLS功能。说干就干,马上查找相关资源