温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

linux下分区内部mv和跨分区mv的区别有哪些

发布时间:2021-06-16 14:14:39 来源:亿速云 阅读:208 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关linux下分区内部mv和跨分区mv的区别有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

§ 0x01 问题列表

  1. 为什么不同,为什么一个快一个慢?

  2. 为什么跨区域mv失败时,不影响原来的文件?

这样的释疑过程也是自己对文件系统(filesystem)理解的加深过程。

§ 0x02 原理+释疑

文件系统中文件是如何保存的?

  1. 文件在文件系统中保存时(以linux下的ext2文件系统为例),是通过inode+block组织的。inode对应文件的元数据,block对应真实的数据;

  2. inode对block的管理不能跨分区,因为inode保存的block信息是按照分区中的block序号进行的,脱离对应的分区将没有意义;

  3. linux VFS中文件树是通过inode组件起来的。

分区内部mv的过程:mv a b 因为是在内部移动,所以只是修改了inode的父节点inode。

  1. 将inode a的父节点指向b位置,将inode a对应的文件名,修改为b。

对应的是一个rename的系统调用。

跨分区mv过程:

  1. 分配inode b;

  2. 将a中的block copy到b所在分区中,将对应的block归到inode b之下;

  3. 将inode a删除。

通过以上过程回答2个问题。

  1. 为什么同分区快?因为不涉及底层数据block的拷贝或者移动,数据block都在一个分区内。

  2. 跨分区mv失败时,为什么不影响原来的文件?因为跨分区也是block的copy过程,不是move,在第3步删除inode a之前,a对应的数据都是完整的。

感谢各位的阅读!关于“linux下分区内部mv和跨分区mv的区别有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI