这篇文章给大家分享的是有关linux下分区内部mv和跨分区mv的区别有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
为什么不同,为什么一个快一个慢?
为什么跨区域mv失败时,不影响原来的文件?
这样的释疑过程也是自己对文件系统(filesystem)理解的加深过程。
文件系统中文件是如何保存的?
文件在文件系统中保存时(以linux下的ext2文件系统为例),是通过inode+block组织的。inode对应文件的元数据,block对应真实的数据;
inode对block的管理不能跨分区,因为inode保存的block信息是按照分区中的block序号进行的,脱离对应的分区将没有意义;
linux VFS中文件树是通过inode组件起来的。
分区内部mv的过程:mv a b 因为是在内部移动,所以只是修改了inode的父节点inode。
将inode a的父节点指向b位置,将inode a对应的文件名,修改为b。
对应的是一个rename的系统调用。
跨分区mv过程:
分配inode b;
将a中的block copy到b所在分区中,将对应的block归到inode b之下;
将inode a删除。
通过以上过程回答2个问题。
为什么同分区快?因为不涉及底层数据block的拷贝或者移动,数据block都在一个分区内。
跨分区mv失败时,为什么不影响原来的文件?因为跨分区也是block的copy过程,不是move,在第3步删除inode a之前,a对应的数据都是完整的。
感谢各位的阅读!关于“linux下分区内部mv和跨分区mv的区别有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。