Linux基础之-BTRFS文件系统

BTRFS

BTRFS(通常念成Butter FS),被称为下一代的LINUX文件系统,由Oracle于2007年宣布并进行中的COW(copy-on-write式)文件系统。目标是取代Linux目前的ext3文件系统,改善ext3的限制,特别是单一文件大小的限制,总文件系统大小限制以及加入文件校验和特性。加入目前ext3/4未支持的一些功能,例如可写的磁盘快照(snapshots),以及支持递归的快照(snapshots of snapshots),内建磁盘阵列(RAID)支持,支持子卷(Subvolumes)的概念,允许在线调整文件系统大小。

BTRFS特性:

首先是扩展性 (scalability) 相关的特性,btrfs 最重要的设计目标是应对大型机器对文件系统的扩展性要求。 Extent,B-Tree和动态 inode 创建等特性保证了 btrfs 在大型机器上仍有卓越的表现,其整体性能而不会随着系统容量的增加而降低。

其次是数据一致性 (data integrity) 相关的特性。系统面临不可预料的硬件故障,Btrfs 采用 COW 事务技术来保证文件系统的一致性。 btrfs 还支持 checksum,避免了 silent corrupt 的出现。而传统文件系统则无法做到这一点。

第三是和多设备管理相关的特性。 Btrfs 支持创建快照 (snapshot),和克隆 (clone) 。 btrfs 还能够方便的管理多个物理设备,使得传统的卷管理软件变得多余。

最后是其他难以归类的特性。这些特性都是比较先进的技术,能够显著提高文件系统的时间 / 空间性能,包括延迟分配,小文件的存储优化,目录索引等。

优化支持

SSD 是固态存储 Solid State Disk 的简称。在过去的几十年中,CPU/RAM 等器件的发展始终遵循着摩尔定律,但硬盘 HDD 的读写速率却始终没有飞跃式的发展。磁盘 IO 始终是系统性能的瓶颈。

SSD 采用 flash memory 技术,内部没有磁盘磁头等机械装置,读写速率大幅度提升。 flash memory 有一些不同于 HDD 的特性。 flash 在写数据之前必须先执行擦除操作;其次,flash 对擦除操作的次数有一定的限制,在目前的技术水平下,对同一个数据单元最多能进行约 10 万次擦除操作,因此,为了延长 flash 的寿命,应该将写操作平均到整个 flash 上。

SSD 在硬件内部的微代码中实现了 wear leveling 等分布写操作的技术,因此系统无须再使用特殊的 MTD 驱动和 FTL 层。虽然 SSD 在硬件层面做了很多努力,但毕竟还是有限。文件系统针对 SSD 的特性做优化不仅能提高 SSD 的使用寿命,而且能提高读写性能。 Btrfs 是少数专门对 SSD 进行优化的文件系统。 btrfs 用户可以使用 mount 参数打开对 SSD 的特殊优化处理。

Btrfs 的 COW 技术从根本上避免了对同一个物理单元的反复写操作。如果用户打开了 SSD 优化选项,btrfs 将在底层的块空间分配策略上进行优化:将多次磁盘空间分配请求聚合成一个大小为 2M 的连续的块。大块连续地址的 IO 能够让固化在 SSD 内部的微代码更好的进行读写优化,从而提高 IO 性能 。

btrfs文件系统的创建

使用 mkfs.btrfs 命令来创建BTRFS文件系统(Centos 7):

查看系统上现有的硬盘、分区信息,我们使用3块空闲硬盘来创建BTRFS(在同一个分区上创建BTRFS意义不大):

默认DATA数据存储类型为:RAID0,元数据METADATA存储类型为:RAID1,后面可以通过命令来修改RAID模式

挂载使用BTRFS,3个组成的磁盘都可以成为挂载设备:

查看BTRFS信息:

调整BTRFS的大小,先减少10G,再增加2G,最后扩容到最大:

由于BTRFS 支持在线调整,不需要事先卸载。

下面将其中一块硬盘移除出BTRFS,这之前先拷贝一些文件进来,前后对比文件读写是否有问题:

下面将 /dev/sdb 磁盘移除,BTRFS在移除设备时会先自动移动数据,查看分区内的文件是否能正常读取:

注:移除分区内的存储文件不足以在剩余的BTRFS空间上保存时,数据将会丢失请谨慎操作!

下面将刚才移除的 /dev/sdb 重新添加进来:

使用 balance 选项开启平衡特性,这个时间因数据大小而延长。

下面我们使用 balance start 参数将数据、元数据的RAID类型更改为RAID5(RAID5需要至少3块硬盘,不然会转换失败):

BTRFS还支持创建多个子卷,相当于多个分区,子卷可以分别挂载到系统的不同路径下:

使用 balance   list   show 选项可以显示子卷名称、信息:

使用 balance snapshot选项给子卷创建快照:

使用 btrfs-convert 可以将其他类型的分区,在不损坏分区存储文件的前提下转换为BTRFS类型:

我们将 /dev/sdb1 和 sdb2 分区都转换成BTRFS类型,验证文件是否能正常读写:

之前2个分区挂载、读写都正常:

卸载2个分区后,分别转换,然后重新挂载:

使用 -r 选项可以还原到原先的分区类型:

 

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值