用于归档日志文件的脚本

Mer*_*cer 1 linux bash

我已经创建了一个用于存档日志文件的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
Run Code Online (Sandbox Code Playgroud)

我经历的输出是:

[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
Run Code Online (Sandbox Code Playgroud)

当我执行我的脚本时,为什么我的档案中有所有文件?我只想要匹配的文件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
Run Code Online (Sandbox Code Playgroud)

pnd*_*ndc 10

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

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