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 / 问题 / 518326
Accepted
43Tesseracts
43Tesseracts
Asked: 2019-05-11 14:02:50 +0800 CST2019-05-11 14:02:50 +0800 CST 2019-05-11 14:02:50 +0800 CST

发现没有返回预期的文件

  • 772

我正在尝试在特定位置查找一些大文件:

此命令有效并返回一些结果:

admin@tyrell:~$ sudo find /nfshome/*/.local/ -type f -size +1G -exec ls -lh {} \;
-rw-r--r-- 1 9917183 students 5.2G Jun  5  2017 /nfshome/9917183/.local/share/Trash/files/result_25.zip
-rw-r--r-- 1 9918178 students 4.0G Sep  6  2018 /nfshome/9918178/.local/share/unity3d/Asset Store-5.x/Unity Technologies/Unity EssentialsSample Projects/3D Game Kit.unitypackage
-rw-r--r-- 1 9919185 students 2.1G Mar  6  2018 /nfshome/9919185/.local/share/Trash/files/agggg.avi
-rw-r--r-- 1 9919382 students 1.7G Jan 17  2017 /nfshome/9919382/.local/share/Trash/files/MageWar.avi
-rw-r--r-- 1 9921459 students 1.8G Apr 12 11:58 /nfshome/9921459/.local/share/Trash/files/takeout-20190412T182950Z-001(1).zip
-rw-r--r-- 1 9921459 students 1.8G Apr 12 11:58 /nfshome/9921459/.local/share/Trash/files/takeout-20190412T182950Z-001.zip
-rw-r--r-- 1 9921459 students 1.4G Apr 12 11:56 /nfshome/9921459/.local/share/Trash/files/takeout-20190412T182950Z-003.zip
-rw-r--r-- 1 9921459 students 1.4G Apr 12 11:58 /nfshome/9921459/.local/share/Trash/files/takeout-20190412T182950Z-003(1).zip

但是如果我尝试通过添加一个子目录来缩小搜索范围share/,我什么也得不到,我希望得到完全相同的结果,因为上面的所有内容都在share/:

admin@tyrell:~$ sudo find /nfshome/*/.local/share/ -type f -size +1G -exec ls -lh {} \;
admin@tyrell:~$ 

为什么 find 不返回与第一个命令相同的结果?

find
  • 2 2 个回答
  • 882 Views

2 个回答

  • Voted
  1. BowlOfRed
    2019-05-11T14:21:24+08:002019-05-11T14:21:24+08:00

    在您的命令中,sudoonly 赋予命令额外权限find,而不是 shell。因此,如果您从高处开始,find则能够下降到文件树中并向您显示内容。

    但是您的外壳正在尝试扩展*. 如果您的用户没有权限检查 的内容/nfshome/*/.local,那么它将无法匹配其中的任何文件(例如/nfshome/*/.local/share)。如果没有匹配,则不会传递任何内容find。

    您可以通过检查 和 的输出来看到这echo /nfshome/*/.local一点echo /nfshome/*/.local/share。第二个可能是空的。

    目前尚不清楚为什么要在第一个命令似乎起作用时执行第二个命令。您可以在子 shell 中运行整个命令,并使用sudo. 如sudo -c "find ..."

    • 4
  2. Best Answer
    roaima
    2019-05-11T14:32:03+08:002019-05-11T14:32:03+08:00

    失败的原因与权限和通配符有关*。我们可以像这样在本地文件系统上重现它:

    1. 设置场景,目录树下/tmp/top:

      sudo -s <<'x'
      mkdir -p /tmp/top/{a,b}/dir/sub/
      touch /tmp/top/{a,b}/dir/sub/file
      chown root /tmp/top/?/dir
      chmod go= /tmp/top/?/dir
      x
      
    2. 请注意,作为普通用户,我们无权进行以下操作/tmp/top/*/dir:

      find /tmp/top/?/dir -type f
      find: ‘/tmp/top/a/dir’: Permission denied
      find: ‘/tmp/top/b/dir’: Permission denied
      
    3. 尝试从普通用户无法访问的目录以 root 权限下降:

      sudo find /tmp/top/*/dir/sub -type f
      find: ‘/tmp/top/*/dir/sub’: No such file or directory
      

      请记住,shell 通配符的评估发生在命令执行之前。所以这里发生的是包含通配符的路径*被扩展。您的普通用户帐户无法验证 的存在sub,因此无法验证整个路径。通配符保留为星号(匹配失败时的默认行为),并且 root 特权被赋予下降find的文字路径。/tmp/top/*/dir/sub该路径不存在,因此出现错误。

    4. 尝试从我们可以作为普通用户访问的目录中以 root 权限下降:

      sudo find /tmp/top/*/dir -type f
      /tmp/top/a/dir/sub/file
      /tmp/top/b/dir/sub/file
      

      这里发生的事情是相似的,但会产生更有用的后果。该路径/tmp/top/*/dir可以完全作为您的普通用户进行评估,从而产生两条路径/tmp/top/a/dir和/tmp/top/b/dir. 这些被传递给 root privileged find,然后它可以通过 root-only 子目录来降低这些 - 并列出它发现的文件。

    在您的情况下,如果.local没有 root 权限,很可能无法访问通配符路径中的目录,但较高级别的目录是可以访问的。当您指定可以作为普通用户帐户评估的路径时,find可以继续使用扩展的路径集。一旦您指定了无法在普通用户帐户的上下文中评估的路径,扩展就会失败并find传递一个包含文字*字符的路径。这当然不匹配和find失败。

    要解决此问题,您只需推迟对路径的评估,直到您的命令以 root 身份运行:

    sudo bash -c "find /nfshome/*/.local/ -type f -size +1G -exec ls -lh {} \;"
    
    • 3

相关问题

  • 如果未引用 -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