百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

tmpwatch命令清除旧文件 清除watch数据

nanshan 2024-12-26 15:44 12 浏览 0 评论

我们知道系统里面常常会有一些忘记删除的长时间不用而且确实没有用处的文件,如果不去处理,这些无用的文件会越来越多,浪费许多系统资源。在不知道文件名的情况下,很难去检查某一目录下到底是哪些文件长时间没有被访问,同时删除这些文件。我们今天就介绍一款非常实用的工具来完成这一工作————tmpwatch

tmpwatch 是什么

tmpwatch 能够循环地删除指定目录下指定时间内没有被访问的文件,这一命令常常用于清理临时文件目录,比如 /tmp 或者 /var/tmp 这类目录。

它只清除指定目录下的空目录、普通文件和符号链接文件,也不会影响其他目录,而且会避开那些属于root用户的系统相关关键文件的。

默认设置下,tmpwatch 命令依据文件的 atime (access time)而非 mtime (modify time)来删除文件。如果你想改变它的删除依据,可以在使用这个命令时加上你想修改的参数。

注意:千万不要在根目录底下运行 tmpwatch 或者 tmpreaper 命令,因为系统可没有任何机制阻止你在根目录下运行此命令。

怎样在 Linux 上安装 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 命令的关键选项和参数

  • 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 -e

0 10 * * * /usr/sbin/tmpwatch 15d /home/daygeek/Downloads

关于 tmpwatch 命令的介绍就到这里了,希望本篇文章对各位读者能有帮助,关于这个命令,你如果还有什么疑问或者其他想法,欢迎留言讨论

> 2020 精选 阿里/腾讯等一线大厂 面试、简历、进阶、电子书 「**良许Linux**」后台回复「**资料**」免费获取

#### 看完的都是真爱,点个赞再走呗?您的「三连」就是良许持续创作的最大动力!

1. 关注**原创**「**良许Linux**」,第一时间获取最新Linux干货!

2. 后台回复【资料】【面试】【简历】获取精选一线大厂面试、自我提升、简历等资料。

3. 关注我的博客:[lxlinux.net](http://www.lxlinux.net)

相关推荐

Let’s Encrypt免费搭建HTTPS网站

HTTPS(全称:HyperTextTransferProtocoloverSecureSocketLayer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入...

使用Nginx配置TCP负载均衡(nginx tcp负载)

假设Kubernetes集群已经配置好,我们将基于CentOS为Nginx创建一个虚拟机。以下是实验种设置的详细信息:Nginx(CenOS8Minimal)-192.168.1.50Kube...

Nginx负载均衡及支持HTTPS与申请免费SSL证书

背景有两台minio文件服务器已做好集群配置,一台是192.168.56.41:9000;另一台是192.168.56.42:9000。应用程序通过Nginx负载均衡调用这两台minio服务,减轻单点...

HTTPS配置实战(https配置文件)

原因现在网站使用HTTPS是规范操作之一,前些日子买了腾讯云服务,同时申请了域名http://www.asap2me.top/,目前该域名只支持HTTP,想升级为HTTPS。关于HTTPS的链接过程大...

只有IP地址没有域名实现HTTPS访问方法

一般来说,要实现HTTPS,得有个注册好的域名才行。但有时候呢,咱只有服务器的IP地址,没注册域名,这种特殊情况下,也能照样实现HTTPS安全访问,按下面这些步骤来就行:第一步,先确认公网...

超详解:HTTPS及配置Django+HTTPS开发环境

众所周知HTTP协议是以TCP协议为基石诞生的一个用于传输Web内容的一个网络协议,在“网络分层模型”中属于“应用层协议”的一种。在这里我们并不研究该协议标准本身,而是从安全角度去探究使用该协议传输数...

Godaddy购买SSL之后Nginx配置流程以及各种错误的解决

完整流程:参考地址:https://sg.godaddy.com/zh/help/nginx-generate-csrs-certificate-signing-requests-3601生成NGI...

Nginx从安装到高可用,一篇搞定(nginx安装与配置详解)

一、Nginx安装1、去官网http://nginx.org/下载对应的nginx包,推荐使用稳定版本2、上传nginx到linux系统3、安装依赖环境(1)安装gcc环境yuminstallgc...

阿里云免费证书申请,配置安装,使用tomcat,支持http/https访问

参数说明商品类型默认已选择云盾证书服务(无需修改)。云盾证书服务类型SSL证书服务的类型。默认已选择云盾SSL证书(无需修改),表示付费版SSL证书。如果您需要免费领取或付费扩容DV单域名证书【免费试...

你试过两步实现Nginx的规范配置吗?极速生成Nginx配置小工具

NGINX是一款轻量级的Web服务器,最强大的功能之一是能够有效地提供HTML和媒体文件等静态内容。NGINX使用异步事件驱动模型,在负载下提供可预测的性能。是当下最受欢迎的高性能的Web...

从零开始搭建HTTPS服务(搭建https网站)

搭建HTTPS服务的最初目的是为了开发微信小程序,因为wx.request只允许发起HTTPS请求,并且还必须和指定的域名进行网络通信。要从零开始搭建一个HTTPS的服务需要下面4...

群晖NAS使用官网域名和自己的域名配置SSL实现HTTPS访问

安全第一步,群晖NAS使用官网域名和自己的域名配置SSL实现HTTPS访问【新手导向】NAS本质还是一个可以随时随地访问的个人数据存储中心,我们在外网访问的时候,特别是在公网IP下,其实会面临着很多安...

让网站快速升级HTTPS协议提高安全性

为什么用HTTPS网络安全越来越受到重视,很多互联网服务网站,都已经升级改造为https协议。https协议下数据包是ssl/tcl加密的,而http包是明文传输。如果请求一旦被拦截,数据就会泄露产生...

用Https方式访问Harbor-1.9版本(https访问流程)

我上周在头条号写过一篇原创文章《Docker-Harbor&Docker-kitematic史上最详细双系统配置手册》,这篇算是它的姊妹篇吧。这篇文章也将用到我在头条写的另一篇原创文章的...

如何启用 HTTPS 并配置免费的 SSL 证书

在Linux服务器上启用HTTPS并配置免费的SSL证书(以Let'sEncrypt为例)可以通过以下步骤完成:---###**一、准备工作**1.**确保域名已解析**...

取消回复欢迎 发表评论: