Loading

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):文件最后一次被访问的时间;
mtime (File Last Modify 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

 

posted @ 2021-02-19 16:22  五月的麦田  阅读(953)  评论(0编辑  收藏  举报