jstack 脚本 自动日志_在 Linux 中使用 Bash 脚本删除早于 “X” 天的文件/文件夹...
该脚本可防止来自 监控工具 的警报,因为我们会在填满磁盘空间之前删除旧的日志文件。
-- Magesh Maruthamuthu(作者)
磁盘使用率 监控工具能够在达到给定阈值时提醒我们。但它们无法自行解决 磁盘使用率 问题。需要手动干预才能解决该问题。
如果你想完全自动化此类操作,你会做什么。是的,可以使用 bash 脚本来完成。
该脚本可防止来自 监控工具 的警报,因为我们会在填满磁盘空间之前删除旧的日志文件。
我们过去做了很多 shell 脚本。如果要查看,请进入下面的链接。
- 如何使用 shell 脚本自动化日常活动?
我在本文中添加了两个 bash 脚本,它们有助于清除旧日志。
1)在 Linux 中删除早于 “X” 天的文件夹的 Bash 脚本
我们有一个名为 /var/log/app/
的文件夹,其中包含 15 天的日志,我们将删除早于 10 天的文件夹。
$ ls -lh /var/log/app/drwxrw-rw- 3 root root 24K Oct 1 23:52 app_log.01
drwxrw-rw- 3 root root 24K Oct 2 23:52 app_log.02
drwxrw-rw- 3 root root 24K Oct 3 23:52 app_log.03
drwxrw-rw- 3 root root 24K Oct 4 23:52 app_log.04
drwxrw-rw- 3 root root 24K Oct 5 23:52 app_log.05
drwxrw-rw- 3 root root 24K Oct 6 23:54 app_log.06
drwxrw-rw- 3 root root 24K Oct 7 23:53 app_log.07
drwxrw-rw- 3 root root 24K Oct 8 23:51 app_log.08
drwxrw-rw- 3 root root 24K Oct 9 23:52 app_log.09
drwxrw-rw- 3 root root 24K Oct 10 23:52 app_log.10
drwxrw-rw- 3 root root 24K Oct 11 23:52 app_log.11
drwxrw-rw- 3 root root 24K Oct 12 23:52 app_log.12
drwxrw-rw- 3 root root 24K Oct 13 23:52 app_log.13
drwxrw-rw- 3 root root 24K Oct 14 23:52 app_log.14
drwxrw-rw- 3 root root 24K Oct 15 23:52 app_log.15
该脚本将删除早于 10 天的文件夹,并通过邮件发送文件夹列表。
你可以根据需要修改 -mtime X
的值。另外,请替换你的电子邮箱,而不是用我们的。
# /opt/script/delete-old-folders.sh#!/bin/bash
prev_count=0
fpath=/var/log/app/app_log.*
find $fpath -type d -mtime +10 -exec ls -ltrh {} ; > /tmp/folder.out
find $fpath -type d -mtime +10 -exec rm -rf {} ;
count=$(cat /tmp/folder.out | wc -l)
if [ "$prev_count" -lt "$count" ] ; then
MESSAGE="/tmp/file1.out"
TO="[email protected]"
echo "Application log folders are deleted older than 15 days" >> $MESSAGE
echo "+----------------------------------------------------+" >> $MESSAGE
echo "" >> $MESSAGE
cat /tmp/folder.out | awk '{print $6,$7,$9}' >> $MESSAGE
echo "" >> $MESSAGE
SUBJECT="WARNING: Apache log files are deleted older than 15 days $(date)"
mail -s "$SUBJECT" "$TO" < $MESSAGE
rm $MESSAGE /tmp/folder.out
fi
给 delete-old-folders.sh
设置可执行权限。
# chmod +x /opt/script/delete-old-folders.sh
最后添加一个 cronjob 自动化此任务。它于每天早上 7 点运行。
# crontab -e0 7 * * * /bin/bash /opt/script/delete-old-folders.sh
你将看到类似下面的输出。
Application log folders are deleted older than 20 days
+--------------------------------------------------------+
Oct 11 /var/log/app/app_log.11
Oct 12 /var/log/app/app_log.12
Oct 13 /var/log/app/app_log.13
Oct 14 /var/log/app/app_log.14
Oct 15 /var/log/app/app_log.15
2)在 Linux 中删除早于 “X” 天的文件的 Bash 脚本
我们有一个名为 /var/log/apache/
的文件夹,其中包含15天的日志,我们将删除 10 天前的文件。
以下文章与该主题相关,因此你可能有兴趣阅读。
- 如何在 Linux 中查找和删除早于 “X” 天和 “X” 小时的文件?
- 如何在 Linux 中查找最近修改的文件/文件夹
- 如何在 Linux 中自动删除或清理 /tmp 文件夹内容?
# ls -lh /var/log/apache/-rw-rw-rw- 3 root root 24K Oct 1 23:52 2daygeek_access.01
-rw-rw-rw- 3 root root 24K Oct 2 23:52 2daygeek_access.02
-rw-rw-rw- 3 root root 24K Oct 3 23:52 2daygeek_access.03
-rw-rw-rw- 3 root root 24K Oct 4 23:52 2daygeek_access.04
-rw-rw-rw- 3 root root 24K Oct 5 23:52 2daygeek_access.05
-rw-rw-rw- 3 root root 24K Oct 6 23:54 2daygeek_access.06
-rw-rw-rw- 3 root root 24K Oct 7 23:53 2daygeek_access.07
-rw-rw-rw- 3 root root 24K Oct 8 23:51 2daygeek_access.08
-rw-rw-rw- 3 root root 24K Oct 9 23:52 2daygeek_access.09
-rw-rw-rw- 3 root root 24K Oct 10 23:52 2daygeek_access.10
-rw-rw-rw- 3 root root 24K Oct 11 23:52 2daygeek_access.11
-rw-rw-rw- 3 root root 24K Oct 12 23:52 2daygeek_access.12
-rw-rw-rw- 3 root root 24K Oct 13 23:52 2daygeek_access.13
-rw-rw-rw- 3 root root 24K Oct 14 23:52 2daygeek_access.14
-rw-rw-rw- 3 root root 24K Oct 15 23:52 2daygeek_access.15
该脚本将删除 10 天前的文件并通过邮件发送文件夹列表。
你可以根据需要修改 -mtime X
的值。另外,请替换你的电子邮箱,而不是用我们的。
# /opt/script/delete-old-files.sh#!/bin/bash
prev_count=0
fpath=/var/log/apache/2daygeek_access.*
find $fpath -type f -mtime +15 -exec ls -ltrd {} ; > /tmp/file.out
find $fpath -type f -mtime +15 -exec rm -rf {} ;
count=$(cat /tmp/file.out | wc -l)
if [ "$prev_count" -lt "$count" ] ; then
MESSAGE="/tmp/file1.out"
TO="[email protected]"
echo "Apache Access log files are deleted older than 20 days" >> $MESSAGE
echo "+--------------------------------------------- +" >> $MESSAGE
echo "" >> $MESSAGE
cat /tmp/file.out | awk '{print $6,$7,$9}' >> $MESSAGE
echo "" >> $MESSAGE
SUBJECT="WARNING: Apache log folders are deleted older than 15 days $(date)"
mail -s "$SUBJECT" "$TO" < $MESSAGE
rm $MESSAGE /tmp/file.out
fi
给 delete-old-files.sh
设置可执行权限。
# chmod +x /opt/script/delete-old-files.sh
最后添加一个 cronjob 自动化此任务。它于每天早上 7 点运行。
# crontab -e0 7 * * * /bin/bash /opt/script/delete-old-folders.sh
你将看到类似下面的输出。
Apache Access log files are deleted older than 20 days
+--------------------------------------------------------+
Oct 11 /var/log/apache/2daygeek_access.11
Oct 12 /var/log/apache/2daygeek_access.12
Oct 13 /var/log/apache/2daygeek_access.13
Oct 14 /var/log/apache/2daygeek_access.14
Oct 15 /var/log/apache/2daygeek_access.15
jstack 脚本 自动日志_在 Linux 中使用 Bash 脚本删除早于 “X” 天的文件/文件夹...相关推荐
- linux下python脚本处理数据_在Linux中通过Python脚本访问mdb数据库的方法
DRIVER={Microsoft Access Driver (*.mdb)};DBQ=c:\\dir\\file.mdb 安装 这里我们需要借助一些库来实现第三方的驱动 我们需要安装这些包:mdb ...
- jstack 脚本 自动日志_运维老司机又翻车, 居然没用过日志切割Logrotate
运维老司机又翻车, 居然没用过日志切割Logrotate 作为一个运维老司机, 这次又翻车了.只能说明一个原因, 就是菜, 所有才要多学习. 说起日志切割, 自己可以说是溜的一批.基本的套路就是在cr ...
- Linux中执行bash脚本报错/bin/bash^M: bad interpreter: No such file or directory
问题描述:Linux中采用绝对路径执行Bash脚本,报错-bash: /home/xxx.sh: /bin/bash^M: bad interpreter: No such file or direc ...
- linux logstash启动脚本,在Linux中从bash脚本启动时Logstash shutdown停止
我写了一个bash脚本,它在指定的文件夹中找到CSV文件,并使用正确的配置文件将它们管道到logstash中.但是,当运行此脚本时,我遇到以下错误,说关闭进程停止,导致无限循环,直到我用ctrl c手 ...
- bash脚本切换管理员_开始为系统管理员使用Bash脚本
bash脚本切换管理员 Bash外壳绝对不是唯一的外壳,但它是功能最强大的外壳之一. 对于需要开发严肃的应用程序的系统管理员来说,这是一种流行的选择,这些应用程序超出了要在系统上运行的简单命令列表的范 ...
- jstack 脚本 自动日志_深入理解jstack日志
Tags : jstack日志发表时间: 2019-03-17 23:53:19 在分析线上问题时常使用到jstack 命令将当时Java应用程序的线程堆栈dump出来. 面对jstack 日志,我们 ...
- jstack 脚本 自动日志_用jstack自动化捕抓异常java代码脚本
#!/bin/bash date=` date +%y%m%d-%H%M` pid=`top -bn1 |grep java | awk '{print $1 "\t" $9}' ...
- jstack 脚本 自动日志_GitLab从安装到全自动化备份一条龙
原文地址[1]欢迎star 需求 1.在新服务器上安装并搭建好gitlab2.手动+自动将旧服务器上的gitlab备份3.手动+自动将gitlab备份包scp到新服务器上4.手动+自动恢复新服务器上的 ...
- linux中利用shell脚本条件执行linux命令
linux中利用shell脚本条件执行命令 在linux环境中,我们总会有一些命令需要经常用,例如经常跳转到某些目录下或者执行某些命令,输入一连串的命令是很烦的,此时我们可以预先写一些脚本然后根据我们 ...
最新文章
- 强类型语言和静态类型语言有什么区别?
- java 的 i++ 和 ++i 的区别
- jsp mysql 判断连接数据库失败 try_急……jsp 连接mysql不知道哪里出异常
- C 免费窗体控件Krypton Toolkit 4 2 0的使用
- Debian下RPM包安装
- 云计算学习笔记003---Hadoop简介,hadoop实现原理,NoSQL介绍...与传统关系型数据库对应关系,云计算面临的挑战
- 获取两个字符串中最大相同子串
- logistic回归分析优点_糖尿病前期患者焦虑现状调查及影响因素分析
- 缓冲器(跟随器)电路
- 股票大宗交易对股价走势的影响
- 语法俱乐部1:基本句型及补语
- (论文阅读笔记)Deep Learning based Recommender System: A Survey and New Perspectives
- D2D与其他短距离通信技术
- Node.js git命令
- 织梦php 文章采集规则,dedecms采集怎么用
- C# 实现窗口程序winform像QQ一样靠近桌面边缘自动隐藏窗口
- Google Play 应用上架流程,谷歌商店上架流程
- 22春天津大学《国际经济法学》在线作业二
- 采坑记录-Redis使用scan代替keys
- 2021年氯化工艺考试总结及氯化工艺复审考试
热门文章
- 天津市全国计算机等级报名时间,天津市2018年全国计算机等级考试报名时间及地点...
- Android动画定义知识小结
- matlab画爱心代码分享
- 基于JAVA+SpringBoot+Vue+Mybatis+MYSQL的社区疫情防控管理系统
- 基于JAVA+SpringBoot+Vue+Mybatis+MYSQL的办公一体化系统
- android java 调用栈_Android开发中打印方法调用栈
- Windows Azure VM Role (2) 创建VHDVHD
- 1.1内置数据类型概述
- ucos实时操作系统应用开发流程
- 寻路优化(一)——二维地图上A*启发函数的设计探索