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 / 问题 / 702552
Accepted
Bruce Adams
Bruce Adams
Asked: 2022-05-15 12:15:02 +0800 CST2022-05-15 12:15:02 +0800 CST 2022-05-15 12:15:02 +0800 CST

写入目录时复制?

  • 772

一些文件系统,特别是 XFS 和 btrfs 支持文件的块级写入时复制。这是通过重新链接文件之间共享底层块的位置来完成的,直到它们被修改。

由于目录本质上是将文件名映射到 inode 的关联数组,因此应该直接对目录执行类似的操作。

是否已经开发了任何可以在 Linux(或任何其他类 Unix 系统)上支持此功能的文件系统?

大概它需要内核支持,就像使用重新链接一样。这是一个类似于copy_file_range () 的调用,它适用于目录。

有没有人积极从事这方面的工作?仅仅是没有人愿意这样做,还是有任何理由说明这是一个坏主意或不必要的?

是否有任何特殊的技术障碍需要克服?

另请参阅https://serverfault.com/questions/129969/is-there-a-way-to-create-a-copy-on-write-copy-of-a-directory 并没有真正回答这个问题。

filesystems copy-on-write
  • 1 1 个回答
  • 104 Views

1 个回答

  • Voted
  1. Best Answer
    Stephen Kitt
    2022-05-17T00:37:34+08:002022-05-17T00:37:34+08:00

    是否有任何特殊的技术障碍需要克服?

    一大障碍是语义上的差异。复制目录(在目标不存在的情况下)会导致其所有内容的副本,以及指向所有这些内容的新目录。特别是,这意味着虽然源目录和目标目录最终包含相同的名称,但每个名称的目标 inode 是不同的。

    如果以与克隆文件相同的方式克隆目录,则最终会得到两个目录,其内容指向相同的 inode — 实际上,您正在创建一个包含指向原始目录内容的硬链接的目录。这对目录不起作用,它为文件创建了令人惊讶的语义——克隆dira包含file, asdirb意味着编辑dirb/file也会编辑dira/file,这可能不是最初的意图。

    因此,这意味着目录副本的共享存储在一般情况下不起作用,并且仅在少数情况下有用。

    copy_file_range并且s但是不要假设底层存储将被共享。FICLONE ioctl它们是“内核,请复制此(部分)文件”形式的请求;它们的好处是可以共享存储,但委托复制比读取和写入更有效。例如,在网络文件系统上,可以在服务器上处理克隆,这比客户端驱动的副本效率高得多。将此推理应用于目录副本,而不必共享底层存储,可能会很有用。

    即使在有用的场景中,内核操作的实现和使用也会很复杂。

    文件克隆操作需要处理单个文件,最初在单个文件系统中。即便如此,copy_file_range跨多个文件系统处理副本的扩展也导致了许多问题。

    目录的“克隆”操作会复杂得多。复制目录不仅包括复制目录本身(即文件名到 inode 的映射),还包括目录的内容。如前所述,您不能只硬链接文件,语义会有所不同;即使这是可以接受的简化,您仍然需要处理无法硬链接的条目,例如您尝试克隆的目录中的目录。然后我们到达安装点,“有趣”的水平就上升了很多。所有这一切当然是在处理权限时。

    假设有人实现了所有这些,那么您需要更新相关的用户空间程序以使用新操作,并将现有代码作为后备。与单文件克隆不同,语义是相当不同的,在所有情况下拼接新函数可能并不容易。由此产生的文件系统语义也不同(可以说,如果它是值得——见relatime和noatime)。

    可能还有其他我还没有想到的障碍;但是第一个表明目录实际上几乎没有机会实际共享存储。

    • 3

相关问题

  • 我应该在 NAS 的 SD 卡中使用哪个文件系统?

  • 如何提前知道 .zip 内部是否有父目录

  • Virtualbox 动态分配磁盘 *.vdi 不断增长

  • du/df 和 ls 报告不同的磁盘使用情况

  • Linux 内核开发人员如何处理数百万行代码的工作?他们是一种方法吗?[关闭]

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