Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式

简介: Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式

Linux手动清理

清理journal日志

目录/var/log/journal

journalctl --vacuum-size=10M

复制

1)只保留近一周的日志

journalctl --vacuum-time=1w

复制

Linux下查找大文件

所有选项:

-a 查看目录中所有文件大小
-b 显示目录文件夹大小,单位b
-k 显示目录文件夹大小,单位kb
-m 显示目录文件夹大小,单位M
-s 显示你指定的或当前目录所有文件总大小
-h 以kb,mb,gb为单位显示

复制

  • 查找大于100M的文件
find . -type f -size +100M

复制

  • 显示全部文件占用空间
du -s /*

复制

  • 显示前10个占用空间最大的文件或目录
du -s * | sort -nr | head

复制

  • 把文件和文件夹列表从小到大排序
du -sh * |sort -n

复制

  • 查找某个文件 并删除他
find -name filename.* | xargs rm -rf

复制

  • 批量查找某个字符并进行替换
sed -i "s/查找字段/替换字段/g" `grep 查找字段 -rl 路径`

复制

Linux删除大量文件会报错 -bash: /bin/rm: Argument list too long

ls | xargs -n 10 rm -fr ls

复制

解释:输出所有的文件名(用空格分割) xargs就是将ls的输出,每10个为一组(以空格为分隔符),作为rm -rf的参数也就是说将所有文件名10个为一组,由rm -rf删除

Linux脚本

CleanLogFile.sh

# 每天早上6点执行    0  6 * * *  sh /log/CleanLogFile.sh
#!/bin/bash
#清理日志路径
path=/var
filename=$path/BigLog.txt
 
#搜索大于10KB的文件
#-size +10k
#搜索小于10KB的文件
#-size -10k
#搜索等于10KB的文件
#-size 10k
 
if [ $# -ne 1 ]  
then  
        #echo "默认设置文件大小为500M"  
        filesize=1k
    else
        filesize=$1
fi 
 
 
echo "设置清除文件大小:$filesize"
 
 
if [  -f "$filename" ]; then    
    rm -rf $filename
    echo  "原始文件已删除"
else
    echo "$filename不存在"
fi 
 
find $path -name "*.*"  -size +$filesize -exec ls -lh {} \; | awk '{ print $5,$9}' > $filename
 
for line in `cat $filename`
do
  #如果有匹配的内容则立即返回状态值0
    echo "$line" | grep -q "$path"
    #$? 是指上一条命令的执行状态, 0就是正常
    if [  $? -eq 0 ]
    then
        #获取文件类型
        filetype=${line#*.}
        if [ $filetype == "zip"  ];then
            echo "rm -rf $line"
            rm -rf $line
        else
            echo "执行清空命令 cat /dev/null > $line"
            cat /dev/null  >  $line
        fi
    fi
done
 

安装定时任务

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

定时任务执行命令

#启动crontab
service crond start
 
crontab -e
#每分钟执行一次(测试用)
*/1 * * * * /usr/local/xiao_sh/CleanLogFile.sh >/dev/null 2>&1
 
#天天凌晨1点执行一次(生产环境)
0 1 * * * /usr/local/xiao_sh/CleanLogFile.sh >/dev/null 2>&1
 
#重载crontab
service crond reload
 
常用命令:
 
   crontab -l    :查看定时任务
 
   crontab -e    :添加任务
 
   crontab -r   :删除任务
 
   cat  /etc/crontab    :查看crontab文件
 
    现在我们来添加一条任务:
 
     59 23 * * * /var/local/CleanLogFile.sh status >>/var/local/clear.txt   
 
    :每天23:59执行脚本并输出到clear.txt文件 ,定时任务的写法:*(分)  *(时) *(日) *(月) *(周) 
 

执行表达式

实例1:每1分钟执行一次cmd,cmd表示要执行的命令
* * * * * cmd
 
实例2:每小时的第3和第15分钟执行
3,15 * * * * cmd
  
实例3:在上午8点到11点的第3和第15分钟执行
3,15 8-11 * * * cmd
 
实例4:每隔两天的上午8点到11点的第3和第15分钟执行
3,15 8-11 */2  *  * cmd
  
实例5:每周一上午8点到11点的第3和第15分钟执行
3,15 8-11 * * 1 cmd
  
实例6:每晚的21:30执行
30 21 * * * cmd
 
实例7:每月1、10、22日的4 : 45执行
45 4 1,10,22 * * cmd
 
实例8:每周六、周日的1 : 10执行
10 1 * * 6,0 cmd
 
实例9:每天18 : 00至23 : 00之间每隔30分钟执行
*/30 18-23 * * * cmd
 
实例10:每星期六的晚上11 : 00 pm执行
0 23 * * 6 cmd
 
实例11:每一小时执行
0 */1 * * * cmd
 
实例12:晚上11点到早上7点之间,每隔一小时执行
0 23-7 * * * cmd


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
4天前
|
XML SQL 运维
关于日志的清理
关于日志的清理
12 0
|
2天前
|
关系型数据库 MySQL 数据库
mysql数据库bin-log日志管理
mysql数据库bin-log日志管理
|
2天前
|
存储 关系型数据库 数据库
关系型数据库文件方式存储LOG FILE(日志文件)
【5月更文挑战第11天】关系型数据库文件方式存储LOG FILE(日志文件)
8 1
|
3天前
|
运维 监控 安全
Java一分钟之-Log4j与日志记录的重要性
【5月更文挑战第16天】Log4j是Java常用的日志框架,用于灵活地记录程序状态和调试问题。通过设置日志级别和过滤器,可避免日志输出混乱。为防止日志文件过大,可配置滚动策略。关注日志安全性,如Log4j 2.x的CVE-2021-44228漏洞,及时更新至安全版本。合理使用日志能提升故障排查和系统监控效率。
14 0
|
4天前
|
C++
JNI Log 日志输出
JNI Log 日志输出
19 1
|
4天前
|
存储 运维 大数据
聊聊日志硬扫描,阿里 Log Scan 的设计与实践
泛日志(Log/Trace/Metric)是大数据的重要组成,伴随着每一年业务峰值的新脉冲,日志数据量在快速增长。同时,业务数字化运营、软件可观测性等浪潮又在对日志的存储、计算提出更高的要求。
|
4天前
|
存储 监控 安全
Linux ContOS7 日志管理(rsyslog)
Linux ContOS7 日志管理(rsyslog)
|
4天前
|
XML Java Maven
Springboot整合与使用log4j2日志框架【详解版】
该文介绍了如何在Spring Boot中切换默认的LogBack日志系统至Log4j2。首先,需要在Maven依赖中排除`spring-boot-starter-logging`并引入`spring-boot-starter-log4j2`。其次,创建`log4j2-spring.xml`配置文件放在`src/main/resources`下,配置包括控制台和文件的日志输出、日志格式和文件切分策略。此外,可通过在不同环境的`application.yml`中指定不同的log4j2配置文件。最后,文章提到通过示例代码解释了日志格式中的各种占位符含义。
|
存储 监控 网络协议
Linux日志分析工具之AWStats
AWStats是一款功能强大且功能强大的免费工具,可以图形方式生成高级Web,流媒体,ftp或邮件服务器统计信息。此日志分析器用作CGI或命令行, 并在几个图形网页中显示您的日志包含的所有可能信息。
Linux日志分析工具之AWStats
|
监控 Linux
15.8 Linux日志分析工具
日志是非常重要的系统文件,管理员每天的重要工作就是分析和查看服务器的日志,判断服务器的健康状态。但是日志管理又是一项非常枯燥的工作,如果需要管理员手工查看服务器上所有的日志,那实在是一项非常痛苦的工作。有些管理员就会偷懒,省略日志的检测工作,但是这样做非常容易导致服务器出现问题。
281 0
15.8 Linux日志分析工具