1

我创建了一个用于归档日志文件的 Bash 脚本:

#!/bin/bash

# Pour chaque dossiers "log" trouvé.
for folder in $(find . -name log -type d )
do :
    # Pour chaque dossier log contenant des fichiers ".log" vieux de +30jours.
    for file in $(find $folder -name "*.log" -mtime +30)
    do :
            # Archiver les fichiers ".log".
        tar czf archive-log.tar.gz $folder/*.log
    done

    # Si une archive existe.
    if [ -e $folder/*.tar.gz ]
         # Déplacer l'archive.
         then mv $folder/*.tar.gz $ARCHIVE
    fi

done

我体验的输出是:

[logs]$ ll
total 8
drwxr-xr-x 2 webadm webgrp 4096 sep 17 14:26 log_weblogic
-rwxr--r-- 1 webadm webgrp  456 sep 17 14:31 scriptArchivesLog

[log_weblogic]$ ll
total 200
-rw-r----- 1 webadm webgrp 98005 mai 16 04:04 test.log
-rw-r----- 1 webadm webgrp 98005 sep 13 15:29 WLS-CONSOLE-DOMAINE-PUB.log


[logs]$ ll
total 32
-rw-r--r-- 1 webadm webgrp 21734 sep 17 14:31 archive-log.tar.gz
drwxr-xr-x 2 webadm webgrp  4096 sep 17 14:26 log_weblogic
-rwxr--r-- 1 webadm webgrp   456 sep 17 14:31 scriptArchivesLog

当我执行我的脚本时,为什么我的存档中有所有文件?我只想要匹配的文件mtime +30

[logs]$ tar tvzf archive-log.tar.gz
-rw-r----- webadm/webgrp 98005 2013-05-16 04:04:00 ./log_weblogic/test.log
-rw-r----- webadm/webgrp 98005 2013-09-13 15:29:03 ./log_weblogic/WLS-CONSOLE-DOMAINE-PUB.log
4

5 回答 5

10

您犯了一个严重错误,即没有检查是否已经有一个程序或库可以满足您的需求。在这种情况下,您的系统上可能已经存在 logrotate,它正在努力清理 /var/log 中的系统日志文件。作为奖励,它也已经配置为定期运行,因此您甚至不必记住设置 cron 作业。

https://www.linode.com/docs/uptime/logs/use-logrotate-to-manage-log-files有一个使用 logrotate 的教程

于 2013-09-17T13:15:54.110 回答
2

替换以下内容:

for file in $(find $folder -name "*.log" -mtime +30)
do :
        # Archiver les fichiers ".log".
    tar czf archive-log.tar.gz $folder/*.log
done

tar czf archive-log.tar.gz $(find $folder -name "*.log" -mtime +30)
于 2013-09-17T12:52:00.357 回答
1

这是因为您的 tar 命令:

tar czf archive-log.tar.gz $folder/*.log

这实际上是归档所有*.log文件,而与这些文件上的时间戳无关。

gnu-tar有一个开关:

--newer-mtime=date

对于这个用例。

于 2013-09-17T12:46:40.257 回答
0

试试这个:

for folder in $(find . -name log -type d ) # Pour chaque dossiers "log" trouvé.
do :
    for file in $(find $folder -name "*.log" -mtime +30) # Pour chaque dossier log contenant des fichiers ".log" vieux de +30jours.
    do :
        tar czf archive-log.tar.gz $folder/*.log && rm -f $folder/*.log  # Archiver les fichiers ".log". and remove the copy
    done

    if [ -e $folder/*.tar.gz ] # Si une archive existe.
         then mv $folder/*.tar.gz $ARCHIVE # Déplacer l'archive.
    fi

done
于 2013-09-17T12:46:25.393 回答
0

这是错误的部分:

for file in $(find $folder -name "*.log" -mtime +30) # Pour chaque dossier log contenant des fichiers ".log" vieux de +30jours.
do :
    tar czf archive-log.tar.gz $folder/*.log # Archiver les fichiers ".log".
done

尽管搜索文件,tar czf archive-log.tar.gz $folder/*.log仍会归档所有这些文件。

您可以将其更改为以下内容:

readarray -t files < <(exec find $folder -name "*.log" -mtime +30) ## read those files (list) to array
[[ ${#files[@]} -gt 0 ]] && tar czf archive-log.tar.gz "${files[@]}"  ## create an archive if a file was found.
于 2013-09-17T12:48:28.750 回答