0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

用cp命令0.2秒就拷贝了100G文件是怎么回事

Linux爱好者 ? 来源:OSC开源社区 ? 作者:OSC开源社区 ? 2021-11-02 15:22 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

cp 引发的思考

今天同事用 cp 命令,把他给惊到了!背景是这样的:他用 cp 拷贝了一个 100 G的文件,竟然一秒不到就拷贝完成了!用 ls 看一把文件,显示文件确实是 100 G。

sh-4.4# ls -lh -rw-r--r-- 1 root root 100G Mar 6 12:22 test.txt

但是copy起来为什么会这么快呢?

sh-4.4# time cp 。/test.txt 。/test.txt.cp real 0m0.107s user 0m0.008s sys 0m0.085s

一个 SATA 机械盘的写能力能到 150 M/s (大部分的机械盘都是到不了这个值的)就算非常不错了,正常情况下,copy 一个 100G 的文件至少要 682 秒 ( 100 G/ 150 M/s ),也就是 11 分钟。实际情况却是 cp 一秒没到就完成了工作,惊呆了,为啥呢?更诡异的是:他的文件系统只有 40 G,为啥里面会有一个 100 G的文件呢?同事把我找来,看看这个诡异的问题。

分析文件我让他先用 du 命令看一下,却只有 2M ,根本不是100G,这是怎么回事?

sh-4.4# du -sh 。/test.txt 2.0M 。/test.txt

再看 stat 命令显示的信息:

sh-4.4# stat 。/test.txt File: 。/test.txt Size: 107374182400 Blocks: 4096 IO Block: 4096 regular file Device: 78h/120d Inode: 3148347 Links: 1 Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root) Access: 2021-03-13 1200.888871000 +0000 Modify: 2021-03-13 1246.562243000 +0000 Change: 2021-03-13 1246.562243000 +0000 Birth: -

stat 命令输出解释:

Size 为 107374182400(知识点:单位是字节),也就是 100G ;

Blocks 这个指标显示为 4096(知识点:一个 Block 的单位固定是 512 字节,也就是一个扇区的大小),这里表示为 2M;

划重点:

Size 表示的是文件大小,这个也是大多数人看到的大小;

Blocks 表示的是物理实际占用空间;

同事问道:“文件大小和实际物理占用,这两个竟然不是相同的概念 !为什么是这样? ” “看来,我们必须得深入文件系统才能理解了,来,我给你好好讲讲。”

文件系统

文件系统听起来很高大上,通俗话就用来存数据的一个容器而已,本质和你的行李箱、仓库没有啥区别,只不过文件系统存储的是数字产品而已。我有一个视频文件,我把这个视频放到这个文件系统里,下次来拿,要能拿到我完整的视频文件数据,这就是文件系统,对外提供的就是存取服务。

现实的存取场景例如你到火车站使用寄存服务:存行李的时候,是不是要登记一些个人信息?对吧,至少自己名字要写上。可能还会给你一个牌子,让你挂手上,这个东西就是为了标示每一个唯一的行李。

取行李的时候,要报自己名字,有牌子的给他牌子,然后工作人员才能去特定的位置找到你的行李

划重点:存的时候必须记录一些关键信息(记录ID、给身份牌),取的时候才能正确定位到。

文件系统回到我们的文件系统,对比上面的行李存取行为,可以做个简单的类比;

登记名字就是在文件系统记录文件名;

生成的牌子就是元数据索引

你的行李就是文件;

寄存室就是磁盘(容纳东西的物理空间);

管理员整套运行机制就是文件系统;

上面的对应并不是非常严谨,仅仅是帮助大家理解文件系统而已,让大家知道其实文件系统是非常朴实的一个东西,思想都来源于生活。

空间管理现在思考文件系统是怎么管理空间的?如果,一个连续的大磁盘空间给你使用,你会怎么使用这段空间呢?直观的一个想法,我把进来的数据就完整的放进去。

这种方式非常容易实现,属于眼前最简单,以后最麻烦的方式。因为会造成很多空洞,明明还有很多空间位置,但是由于整个太大,形状不合适(数据大小),哪里都放不下。因为你要放一个完整的空间。怎么改进?有人会想,既然整个放不进去,那就剁碎了呗。这里塞一点,那里塞一点,就塞进去了。对,思路完全正确。改进的方式就是切分,把空间按照一定粒度切分。每个小粒度的物理块命名为 Block,每个 Block 一般是 4K 大小,用户数据存到文件系统里来自然也是要切分,存储到磁盘上各个角落。

图示标号表示这个完整对象的 Block 的序号,用来复原对象用的。随之而来又有一个问题:你光会切成块还不行,取文件数据的时候,还得把它们给组合起来才行。所以,要有一个表记录文件对应所有 Block 的位置,这个表被文件系统称为inode。写文件的流程是这样的:

先写数据:数据先按照 Block 粒度存储到磁盘的各个位置;

再写元数据:然后把 Block 所在的各个位置保存起来,即inode(我用一本书来表示);

读文件流程则是:

先读inode,找到各个 Block 的位置;

然后读数据,构造一个完整的文件,给到用户;

inode/block 概念好,我们现在来看看inode,直观地感受一下:这个inode有文件元数据和Block数组(长度是15),数组中前两项指向Block 3和Block 11,表示数据在这两个块中存着。 你肯定会意识到:Block数组只有15个元素,每个Block是4K, 难道一个文件最大只能是 15 * 4K = 60 K ? 这是绝对不行的! 最简单的办法就是:把这个Block数组长度给扩大!比如我们想让文件系统最大支持100G的文件,Block数组需要这么长:(100*1024*1024)/4 = 26214400Block数组中每一项是4个字节,那就需要(26214400*4)/1024/1024 = 100M 为了支持100G的文件,我们的Block数组本身就得100M ! 并且对每个文件都是如此 !即使这个文件只有1K! 这将是巨大浪费!肯定不能这么干,解决方案就是间接索引,按照约定,把这 15 个槽位分作 4 个不同类别来用:

前 12 个槽位(也就是 0 - 11 )我们成为直接索引;

第 13 个位置,我们称为 1 级索引;

第 14 个位置,我们称为 2 级索引;

第 15 个位置,我们称为 3 级索引;

直接索引:能存 12 个 block 编号,每个 block 4K,就是 48K,也就是说,48K 以内的文件,前 12 个槽位存储编号就能完全 hold 住。一级索引:也就是说这里存储的编号指向的 block 里面存储的也是 block 编号,里面的编号指向用户数据。一个 block 4K,每个元素 4 字节,也就是有 1024 个编号位置可以存储。所以,一级索引能寻址 4M(1024 * 4K)空间 。二级索引:二级索引是在一级索引的基础上多了一级而已,换算下来,有了 4M 的空间用来存储用户数据的编号。所以二级索引能寻址 4G (4M/4 * 4K) 的空间。

三级索引:三级索引是在二级索引的基础上又多了一级,也就是说,有了 4G 的空间来存储用户数据的 block 编号。所以二级索引能寻址 4T (4G/4 * 4K) 的空间。

所以,在这种文件系统(如ext2)上,通过这种间接块索引的方式,最大能支撑的文件大小 = 48K + 4M + 4G + 4T ,约等于 4 T。这种多级索引寻址性能表现怎么样?在不超过 12 个数据块的小文件的寻址是最快的,访问文件中的任意数据理论只需要两次读盘,一次读 inode,一次读数据块。访问大文件中的数据则需要最多五次读盘操作:inode、一级间接寻址块、二级间接寻址块、三级间接寻址块、数据块。

为什么cp那么快?接下来我们要写入一个奇怪的文件,这个文件很大,但是真正的数据只有8K:在[0,4K]这位置有4K的数据在[1T , 1T+4K] 处也有4K数据中间没有数据,这样的文件该如何写入硬盘?

创建一个文件,这个时候分配一个 inode;

在 [ 0,4K ] 的位置写入 4K 数据,这个时候只需要 一个 block,把这个编号写到 block[0] 这个位置保存起来;

在 [ 1T,1T+4K ] 的位置写入 4K 数据,这个时候需要分配一个 block,因为这个位置已经落到三级索引才能表现的空间了,所以需要还需要分配出 3 个索引块;

写入完成,close 文件;

这个时候,我们的文件看起来是超大文件,size 等于 1T+4K ,但里面实际的数据只有 8 K,位置分别是 [ 0,4K ] ,[ 1T,1T+4K ]。 由于没写数据的地方不用分配物理block块,所以实际占用的物理空间只有8K。重点:文件 size 只是 inode 里面的一个属性,实际物理空间占用则是要看用户数据放了多少个 block ,没写数据的地方不用分配物理block块。这样的文件其实就是稀疏文件, 它的逻辑大小和实际物理空间是不相等的。 所以当我们用cp命令去复制一个这样的文件时,那肯定迅速就完成了。

总结好,我们再深入思考下,文件系统为什么能做到这一点?

首先,最关键的是把磁盘空间切成离散的、定长的 block 来管理;

然后,通过 inode 能查找到所有离散的数据(保存了所有的索引);

最后,实现索引块和数据块空间的后分配;

这三点是层层递进的。

后记

我把这点小知识给小伙伴讲了一小时,看到他感动欲哭的表情,我觉得他学fei了,非常满意。是我想太多了吗?中午吃饭都没叫我。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 命令
    +关注

    关注

    5

    文章

    744

    浏览量

    22980
  • 代码
    +关注

    关注

    30

    文章

    4908

    浏览量

    71272

原文标题:0.2 秒居然复制了 100G 文件?

文章出处:【微信号:LinuxHub,微信公众号:Linux爱好者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    创新驱动未来:睿海光电领跑100G光模块技术,赋能AI时代智算网络

    一、100G光模块:下一代网络的核心基础设施? 随着全球数据中心、云计算和人工智能的爆发式增长,100G光模块已成为高速互联的核心组件。其凭借25Gbps×4通道的高效传输架构[3],实现低功耗
    的头像 发表于 08-20 18:18 ?96次阅读
    创新驱动未来:睿海光电领跑<b class='flag-5'>100G</b>光模块技术,赋能AI时代智算网络

    创新驱动智算互联:睿海光电以100G光模块技术引领未来网络发展

    的基础组件。其采用4×25Gbps通道架构,成功实现高带宽、低功耗与高端口密度的理想结合。从IEEE标准下的100GBASE-SR10(多模短距)、100GBASE-LR4(单模10公里)到MSA推动的PSM4(500米并行单
    的头像 发表于 08-20 13:51 ?79次阅读

    100G光模块:解码未来网络的高效引擎,睿海光电以创新领跑行业

    在人工智能、云计算与算力需求爆发的时代,100G光模块作为高速数据传输的“神经枢纽”,已成为构建智能网络的核心组件。作为该领域的领军企业,深圳市睿海光电科技有限公司(以下简称“睿海光电”)凭借
    的头像 发表于 08-20 09:23 ?82次阅读

    100G 高速线缆:睿海光电以技术突破构筑智算互联的高效基石

    在人工智能大模型训练需求爆发与全球智算中心加速布局的背景下,数据中心内部短距互联的效率成为制约算力释放的关键瓶颈。100G 高速线缆凭借其高带宽、低延迟的特性,已成为连接服务器、交换机与存储设备
    的头像 发表于 08-19 14:52 ?125次阅读

    100G 高速线缆:睿海光电以技术突破与极速响应赋能智算互联新时代

    在人工智能大模型训练、云计算集群扩容与超算中心算力跃升的驱动下,100G 高速线缆作为数据中心内部短距互联的核心载体,其性能、兼容性与部署效率直接决定智算网络的运行效能。深圳市睿海光电科技有限公司
    的头像 发表于 08-19 14:51 ?136次阅读

    睿海光电:100G光模块技术创新与全球数字化赋能

    睿海光电:100G光模块技术创新与全球数字化赋能 在全球数字化转型加速的背景下,高速光通信技术正成为支撑AI、云计算等新兴产业发展的重要基石。作为这一领域的领军企业,睿海光电凭借其在100G光模块
    的头像 发表于 08-18 13:53 ?139次阅读

    410?基于?XCVU9P+?C6678?的?100G?光纤的加速卡

    基于 XCVU9P+ C6678 的 100G 光纤的加速卡
    的头像 发表于 05-08 08:32 ?327次阅读
    410?基于?XCVU9P+?C6678?的?<b class='flag-5'>100G</b>?光纤的加速卡

    PWM控制SCR,调节负载输出电压的实验中,斩波后的负载电压波形偏离0V-x轴100v是怎么回事

    您好:请问PWM控制SCR,调节负载输出电压的实验中,斩波后的负载电压波形偏离0V-x轴100v是怎么回事?此时PWM占空比为40%。[/td]
    发表于 03-11 07:07

    STM32G474ymodem传文件时,传输停止怎么回事

    ,按照示例,tera term进行IAP。前面的操作和执行都没有问题,但是,ymodem传文件时,传输停止。 这是怎么回事? 请帮我看
    发表于 03-10 07:14

    100G光模块概述及应用前景

    100G光模块作为高速数据传输的核心组件,具有重要地位。100G光模块可以实现每秒100Gbps的数据传输速度,广泛应用于数据中心和传输网等应用场景。本文将介绍100G光模块的基本类型
    的头像 发表于 11-25 12:04 ?884次阅读

    LMP90100采集CH1=VIN1-VIN6的时候,采集到的AD值有的时候是正有的时候是负值是怎么回事

    =VIN1-VIN6 的时候,采集到的AD值有的时候是正有的时候是负值是怎么回事?按理说CH1应该在+0.2mV左右,应该一直是正的。
    发表于 11-25 07:01

    mpo预端接光缆可以支持100G或400G光网络吗

    MPO(多点光纤预端接器)预端接光缆可以支持100G或400G光网络,但具体支持的速率取决于多个因素: MPO类型:不同类型的MPO连接器可以支持不同数量的光纤通道。常见的MPO连接器类型包括
    的头像 发表于 10-15 10:05 ?947次阅读

    如何使用SCP和Rsync远程拷贝文件

    scp是secure copy的简写,用于在Linux下进行远程拷贝文件命令,和它类似的命令cp,不过
    的头像 发表于 09-29 15:54 ?1042次阅读

    基于VU9P的4路 100G光纤 6U VPX板卡

    基于VU9P的4路 100G光纤 6U VPX板卡
    的头像 发表于 09-29 09:28 ?1035次阅读
    基于VU9P的4路 <b class='flag-5'>100G</b>光纤 6U VPX板卡

    大带宽服务器推流延迟怎么回事

    大带宽服务器推流延迟怎么回事
    的头像 发表于 09-03 14:52 ?824次阅读