AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 787860
Accepted
user1578026
user1578026
Asked: 2024-12-09 12:27:00 +0800 CST2024-12-09 12:27:00 +0800 CST 2024-12-09 12:27:00 +0800 CST

为什么我不能使用 find 来扫描已修改的文件中是否存在病毒和恶意软件?

  • 772
该问题已从 Server Fault迁移,因为它可以在 Unix & Linux Stack Exchange 上找到答案。14 小时前迁移 。

我需要扫描 Linux 系统中的病毒/恶意软件,仅扫描整个文件系统。有几个选项可以考虑。

  • 一种是用户通常的做法:每天使用防病毒软件扫描一次系统。
  • 第二个选项是查找过去一天修改的文件并将该列表提供给防病毒程序。

我在包含 500 万个空文件的目录上测试了以下 bash 命令find,它非常高效。

date;find /test/ -type f -ctime -1 -type f 1>./find_ctime.out 2>./find.errors;date

只需约5秒。

我使用 -ctime 选项只是为了克服使用 touch 等实用程序更改某些程序修改时间的问题。

大多数管理员在谈论系统扫描时都会谈论使用防病毒软件进行完整扫描。

为什么不可以使用 find 来获取修改的文件列表并对其进行扫描?

find
  • 1 1 个回答
  • 521 Views

1 个回答

  • Voted
  1. Best Answer
    jesse_b
    2024-12-09T21:03:41+08:002024-12-09T21:03:41+08:00

    只要您除了增量扫描之外还定期进行完整系统扫描,这可能不是最糟糕的想法,但也有一些缺点:

    并非所有漏洞都需要修改文件

    一些漏洞可能潜伏在旧文件中,而旧防病毒签名根本无法发现这些漏洞。因此,当新签名发布时,他们可能会在旧文件中发现威胁。

    文件修改时间很奇怪

    Linux 中的文件修改和更改时间存在各种奇怪和不一致的情况。

    • 并非所有文件系统都支持 ctime 和 mtime,而支持的文件系统并不总是使用它。
    • 你可以任意改变 ctime 和 mtime 为你想要的任何值
    • 如果你直接使用类似命令写入磁盘,dd则可以绕过 mtime/ctimes
    • 如果文件是内存映射的,则可以修改它而无需更新磁盘上的 mtime/ctime
    • 网络附加存储上的文件对所有人而言都只是一个自由的狂野西部
    • 可以使用硬链接来操纵文件的修改时间
    • 您可以在修改文件时修改系统时间,然后将其改回来以操作文件修改时间

    因此,考虑到所有这些,如果攻击者知道您的防病毒扫描策略是基于修改/更改时间的,他们可以很容易地使用上述任何一种方法以及可能数十种其他方法来绕过它。

    • 10

相关问题

  • 如果未引用 -name 后面的模式,则 find 的奇怪行为

  • 将变量从子shell打印到父shell [重复]

  • 检查某个文件夹是否存在于某个目录中

  • 从命令行查找和替换 CSS 文件中的颜色

  • GNU find:在-exec中获取绝对和相对路径

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve