filesystems – zfs将root文件系统重命名/移动到child

类似的问题 exists,但解决方案(使用mv)是可怕的,因为在这种情况下,它的工作原理是“复制,然后删除”,而不是纯粹的“移动”.

所以,我创建了一个池:

zpool create tank /dev/loop0

并直接从另一个存储中查找我的数据,以便我的数据现在位于/ tank中.

zfs list
NAME      USED  AVAIL  REFER  MOUNTPOINT
tank      591G  2.10T   591G  /tank

现在我意识到我需要将数据放在子文件系统中,而不是直接放在/ tank文件系统中.

那么如何移动或重命名现有的根文件系统,使其成为池中的子项?

简单重命名不起作用:

zfs rename tank tank/mydata
cannot rename to 'tank/mydata': datasets must be within same pool

(顺便说一句,为什么它会抱怨数据集不在同一个池中,而事实上我只有一个池?)

我知道有些解决方案涉及复制所有数据(mv,或将整个数据集发送到另一台设备并返回),但是不应该有一种简单优雅的方式吗?

只是注意到我不关心现阶段的快照(还没有关注).

解决方法

(请参阅注释中的注释,这可行,但您永远无法删除初始快照,因此这不是一个好的解决方案)

使用ZFS,这非常简单:只需快照,克隆,然后是rm.无需额外空间或复制时间.

zfs snapshot tank@mydata
zfs clone tank@mydata tank/newname
zfs set mountpoint=/beep/boop tank/newname
rm -rf /tank/*

如果在zpool中有其他文件系统,如果不更改挂载点,请注意运行rm -rf.您不希望以意外方式递归删除新文件系统(/ tank / newname)或任何其他子文件系统(tank / *)的内容.一旦确认文件不在根fs(/ tank /)中,并且只在新文件系统中,您也可以删除该初始快照.

zfs delete tank@mydata

相关文章

linux常用进程通信方式包括管道(pipe)、有名管道(FIFO)、...
Linux性能观测工具按类别可分为系统级别和进程级别,系统级别...
本文详细介绍了curl命令基础和高级用法,包括跳过https的证书...
本文包含作者工作中常用到的一些命令,用于诊断网络、磁盘占满...
linux的平均负载表示运行态和就绪态及不可中断状态(正在io)的...
CPU上下文频繁切换会导致系统性能下降,切换分为进程切换、线...