Linux 下使用crontab 定时打包日志并删除已被打包的日志

简介: f=`ls /home/hls/apache-tomcat-7.0.61/logs -1 -c` #获取logs下文件列表( /home/hls/apache-tomcat-7.0.61/logs 是日志的所在的路径)

crontab是和用户相关的,每个用户有自己对应的crontab 。


cron是Linux下的定时执行工具,以下是重启/关闭等等的命令


#/sbin/service crond start    //启动服务
#/sbin/service crond stop     //关闭服务
#/sbin/service crond restart  //重启服务
#/sbin/service crond reload   //重新载入配置
#/sbin/service crond status  //查看服务状态


cron服务提供 crontab命令来设定cron服务的,以下是这个命令的一些参数与说明:


crontab -u 设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数

crontab -l 列出某个用户cron服务的详细内容

crontab -r 删除某个用户的cron服务

crontab -e 编辑某个用户的cron服务


设置定时的参数图:



crontab特殊的符号说明:


  • “*” 代表所有的取值范围内的数字。特别要注意哦!
  • “/” 代表每的意思,如"*/5"表示每5个单位
  • “-” 代表从某个数字到某个数字
  • “,” 分散的数字

例如:


30 21 * * * 表示每晚的21:30

45 4 1,10,22 * * 表示每月1、10、22日的4 : 45


现在是正式代码, 压缩上一个月的日志,并把其删除。


在logs文件夹的同级目录下新建一个 .sh文件 例如:logzip.sh


内容:


echo "Please wait..."  

m=`date -d "1 months ago" +%Y-%m`    #获取上个月的yyyy-mm格式的日期字符串

m2=`date -d "1 months ago" +%Y%m`

index=0

f=`ls /home/hls/apache-tomcat-7.0.61/logs -1 -c`  #获取logs下文件列表( /home/hls/apache-tomcat-7.0.61/logs 是日志的所在的路径)

for name in $f
do
        n=`expr "$name" : '.*\([0-9]\{4\}-[0-9]\{2\}\).*'`    #从文件名称中提取yyyy-mm格式日期
        if [ "$n" != "" ] && [ "$n" = "$m" ]
        then
                f[$index]="/home/hls/apache-tomcat-7.0.61/logs/$name"    #logs文件夹下符合要求的文件名称放入数组
        else
                f[$index]=""
        fi
        (( index ++ ))
done
echo "$f"
str=${f[@]}
if [ "${#str}" -gt 0 ]       #如果大于 0
then
zip /home/hls/apache-tomcat-7.0.61/logs/$m2.zip  $str    #压缩数组中的文件为yyyymm.zip文件,打包放在logs下
else
echo "No files found."
exit 0
fi
echo "$m2.zip maked, now delete old files."
rm -fr $str        #删除已被打包文件
echo "done."
exit 0


使用方法:


执行 crontab -e 编辑当前用户定时任务,进入编辑页面,点击 o ,输入


0 0 1 * * /home/hls/apache-tomcat-7.0.61/logzip.sh >> /home/hls/apache-tomcat-7.0.61/crontablog.log 2>&1

按esc退出编辑 然后 :wq 保存退出。这样就在crontab里设置了定时任务(每月一号凌晨执行logzip.sh,并把执行文件中的日志输出在crontablog.log中)


注意:windows下面创建的文件回车符和linux/unix下面的回车符不一样,可能会导致脚本无法执行

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
27天前
|
Linux Shell
Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式
Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式
79 1
|
20天前
|
存储 监控 安全
Linux系统日志
【4月更文挑战第6天】Linux系统日志,关键用于记录系统状态和事件,包括内核、系统、安全和应用日志,助力管理员诊断问题、确保系统正常运行。日志管理涉及收集、分析、备份等,常用工具如rsyslog、systemd-journal和logrotate(用于日志轮转)。重视日志文件的存储管理,防止空间占用过多。
19 1
Linux系统日志
|
13天前
|
SQL 监控 安全
Linux&Windows 日志分析 陇剑杯 CTF
Linux&Windows 日志分析 陇剑杯 CTF
|
19天前
|
Linux
Linux Crontab 查看定时任务启动没
Linux Crontab 查看定时任务启动没
16 0
Linux Crontab 查看定时任务启动没
|
23天前
|
关系型数据库 MySQL Linux
linux特定服务日志
Linux系统的服务日志在`/var/log`目录下,如系统日志(`/var/log/syslog`或`/var/log/messages`)、认证日志(`/var/log/auth.log`)、SSH日志(`/var/log/auth.log`或`/var/log/secure`)。Web服务器(Apache和Nginx)的访问和错误日志、MySQL错误日志、Postfix及Dovecot邮件服务器日志也在此处。日志位置可能因发行版和服务配置而异,不确定时可查服务配置或用`grep`搜索。使用`logrotate`可管理日志文件大小。
22 6
|
27天前
|
运维 监控 安全
linux日志分析与追踪
在Linux中,日志分析涉及检查 `/var/log` 下的不同文件,如`messages`、`auth.log`、`kern.log`等,以及Web服务器和数据库日志。使用`tail`、`grep`、`awk`等工具实时查看和搜索日志,`logrotate`管理日志大小,`journalctl`处理Systemd日志,而`Splunk`等工具则用于集中式分析。分析技巧包括异常检测、时间关联和阈值监控。安全事件追踪结合登录失败日志、网络嗅探和IDS/IPS。日志链路追踪在分布式系统中尤为重要,帮助定位服务调用问题。有效的日志管理和分析能增强系统安全和故障排除能力。
23 7
|
4月前
|
缓存 Linux Shell
Linux使用crontab定时任务定时备份数据库
Linux使用crontab定时任务定时备份数据库
61 0
|
4月前
|
资源调度 Kubernetes 调度
从 Linux Crontab 到 K8s CronJob,定时任务正在经历怎样的变革
从 Linux Crontab 到 K8s CronJob,定时任务正在经历怎样的变革
118698 59
|
8月前
|
Linux 网络安全
【Linux】crontab 定时任务
【Linux】crontab 定时任务
130 0
|
10月前
|
存储 缓存 监控
【Linux】Crontab 定时任务
这个编辑器真难用。