tmpwatch命令详解
最近一个同事发现自己在/tmp下的运维脚本找不到了,似乎是被删除了。查看了服务器的登录和操作记录没有发现有人为删除痕迹。于是看了一下cron日志,发现有tmpwath的定时任务执行记录,那几乎可以肯定是被这个定时任务删掉了,那么我们就来认识一下tmpwath。
tmpwatch 是什么
Linux系统中我们常常会把一些临时文件或者没有什么用处的文件放置在/tmp下,还有一些进程也会将临时数据放到/var或者/tmp。这些文件如长时间不去处理日积月累可能造成磁盘空间爆满,也浪费磁盘资源。tmpwatch是一款非常实用的空间清理工具,可以帮助我们自动清理/tmp和/var空间的部分目录。
tmpwatch 能够循环地删除指定目录下指定时间内没有被访问的文件,这一命令常常用于清理临时文件目录,比如 /tmp 或者 /var/tmp 这类目录。它只清除指定目录下的空目录、普通文件和符号链接文件,也不会影响其他目录,而且会避开那些属于root用户的系统相关关键文件的。
默认设置下,tmpwatch 命令依据文件的 atime (access time)而非mtime (modify time)来删除文件。如果你想改变它的删除依据,可以在使用这个命令时加上你想修改的参数。
注意:
千万不要在根目录底下运行 tmpwatch 或者 tmpreaper 命令,因为系统可没有任何机制阻止你在根目录下运行此命令。
安装 tmpwatch
各种 Linux 发行版本的安装命令都有些略微差别,具体的安装方法见下文。
如果你的 Linux 发行版本是 REHL/CentOS 6 的话,可以使用 yum 命令来安装 tmpwatch,示例如下:
$ sudo yum install -y tmpwatch
如果你使用的 Linux 发行版本是 Debian 或者 Ubuntu ,则需要使用 apt 或者apt-get 命令来安装 Tmpreaper,示例如下:
$ sudo apt-get install tmpreaper
如果你使用的是 openSUSE,则应使用 zypper 命令安装 tmpwatch:
$ sudo zypper install -y tmpwatch
如果 Linux 发行版本是 Fedora,则应使用 dnf 命令安装 tmpwatch:
$ sudo dnf install -y tmpwatch
说明:在以 Debian 为基础的 Linux 系统,是用 tmpreaper 命令代替 tmpwatch 的,若你使用的系统是以 Debian 为基础的Linux 版本,则将下文的示例中的 tmpwatch 换为 tmpreaper 即可。
tmpwatch使用说明
tmpwatch参数说明
1 -u, --atime 基于访问时间来删除文件,默认的。 2 -m, --mtime 基于修改时间来删除文件。 3 -c, --ctime 基于创建时间来删除文件,对于目录,基于mtime。 4 -M, --dirmtime 删除目录基于目录的修改时间而不是访问时间。 5 -a, --all 删除所有的文件类型,不只是普通文件,符号链接和目录。 6 -d, --nodirs 不尝试删除目录,即使是空目录。 7 -d, --nosymlinks 不尝试删除符号链接。 8 -f, --force 强制删除。 9 -q, --quiet 只报告错误信息。 10 -s, --fuser 如果文件已经是打开状态在删除前,尝试使用“定影”命令。默认不启用。 11 -t, --test 仅作测试,并不真的删除文件或目录。 12 -U, --exclude-user=user 不删除属于谁的文件。 13 -v, --verbose 打印详细信息。 14 -x, --exclude=path 排除路径,如果路径是一个目录,它包含的所有文件被排除了。如果路径不存在,它必须是一个绝对路径不包含符号链接。 15 -X, --exclude-pattern=pattern 排除某规则下的路径。
tmpwatch 命令的关键选项和参数
atime (File Last Access Time):文件最后一次被访问的时间;ctime (File Last Change Time):文件元数据最后一次被修改的时间,即文件相关属性被修改的时间,多数情况下 mtime 和 ctime 值相同,但是诸如文件所有者、权限、所属组这类不涉及内容的属性被修改时则只会影响 ctime;
dirmtime (Directory Last modification time):目录最后一次被修改的时间。
这些时间参数用来设置删除文件的条件阈值:
d:单位为天;
h:单位为小时;
m:单位为分钟;
s:单位为秒。
用 tmpwatch 命令删除一段时间内没有被访问的文件
如前所述,tmpwatch 命令的默认选项是 atime,而默认的单位参数则是h,所以如果你确实要按以小时为单位计算的访问时间来删除文件,那么你不用加任何特殊的选项或则参数后缀,可以直接是用这个命令。如下例所示,即为删除 /tmp 目录下过去5小时内没有被访问的文件:
# tmpwatch 5 /tmp
下面这个示例是删除 /home/daygeek/Downloads 目录下过去十小时内没有修改过内容的文件,注意,如果要按 mtime 来删除文件,需要在命令中加上-m 的选项:
# tmpwatch -m 10 /home/daygeek/Downloads
删除以其他单位计算的某段时间内没有被访问的文件
如果你要以天为单位,则需要加上 d 的后缀,如下为删除30天内没有被访问的文件:
# tmpwatch 30d /home/daygeek/Downloads
删除一段时间内未被使用的所有文件
如果你想不仅仅删除普通文件、符号链接文件、空目录文件,而是想删除指定目录下某段时间内没有被访问的所有文件,则需要加上选项 -a,如下为删除指定目录下12小时未被修改内容的所有文件:
# tmpwatch -am 12 /tmp
将某些目录排除在删除操作外
如下命令可以让那些十小时内没有被修改过内容的目录不被删除:
# tmpwatch -am 10 --nodirs /home/daygeek/Downloads
将特定路径排除在删除操作外
下面的命令删除 /home/daygeek/Downloads 目录下所有十小时内没有修改内容的文件,但是 /home/daygeek/Downloads/Movies 路径下却不受影响,即该路径下十小时内没修改的文件也不会被删除:
# tmpwatch -am 10 --exclude=/home/daygeek/Downloads/Movies /home/daygeek/Downloads
将特定格式的文件排除在删除操作外
下面所示的命令为删除指定文件下的所有10小时内未被改动的文件,除了pdf 格式的文件:
# tmpwatch -am 10 --exclude-pattern='*.pdf' /home/daygeek/Downloads
预演 tmpwatch 的效果
下面这条命令即是对 tmpwatch 的功能效果进行预演:
# tmpwatch -t 5h /home/daygeek/Downloads
用 tmpwatch 设置一个定时任务周期性地执行删除操作
要完成这个任务,会在 /etc/cron.daily/tmpreaper 目录下留下一个 cronjob 文件,这个文件是按照 /etc/timereaper.conf 的设定工作的,你可以按自己的需求设置它。
如下所示的设置,能在每天上午10点时删除指定目录下,十五天没被访问的文件:
# crontab -e0 10 * * * /usr/sbin/tmpwatch 15d /home/daygeek/Downloads
默认定时任务配置
安装后会在/etc/cron.daily/目录下生成一个tmpwatch文件,crontab每天会调用执行一次。内容如下:
1 [roota@redhat6 ~]# cat /etc/cron.daily/tmpwatch 2 #! /bin/sh 3 flags=-umc 4 /usr/sbin/tmpwatch "$flags" -x /tmp/.X11-unix -x /tmp/.XIM-unix \ 5 -x /tmp/.font-unix -x /tmp/.ICE-unix -x /tmp/.Test-unix \ 6 -X '/tmp/hsperfdata_*' -X '/tmp/.hdb*lock' -X '/tmp/.sapstartsrv*.log' \ 7 -X '/tmp/pymp-*' 10d /tmp 8 /usr/sbin/tmpwatch "$flags" 30d /var/tmp 9 for d in /var/{cache/man,catman}/{cat?,X11R6/cat?,local/cat?}; do 10 if [ -d "$d" ]; then 11 /usr/sbin/tmpwatch "$flags" -f 30d "$d" 12 fi 13 done
从配置可以看出tmpwatch排查了/tmp 和 /var 下的一些目录,/tmp保留10d内访问修改过的文件,/var保留30d,其他都删除。
总结:tmpwatch是空间清理的利器,但在测试和使用时也需要注意安全。重要数据切记不要放到/tmp下,尽管其他非特权用户没有权限删除但tmpwatch可以。
参考:https://www.jianshu.com/p/2c6041d8e934