百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术流 > 正文

Linux文件系统介绍:Ext、XFS、Btrfs等,选择适合自己的文件系统

citgpt 2024-07-15 15:18 10 浏览 0 评论

作为 Windows 或 macOS 系统用户,人们一般不会去考虑他们的磁盘使用了什么文件系统,因为微软和苹果已经帮他们选定了 NTFS 和 APFS。而对于 Linux 用户,受益于自由开源软件,文件系统选择非常多,从常见的 Ext 4 文件系统到先进的 Btrfs 文件系统,以及专门为闪存设计的 F2FS 文件系统。在了解各个文件系统特性的基础上,大家可以根据自己的需求和使用场景来选择。

本文介绍了常见的 Linux 文件系统和它们的优缺点,以及使用场合。

Linux文件系统介绍:Ext、XFS、Btrfs等,选择适合自己的文件系统

Ext

Ext 是最为流行的 Linux 文件系统,最新版本 Ext 4 已非常稳定,是过去几年中大多数 Linux 发行版的默认选择。从 Android 2.3 版开始,Ext 4 取代之前的 YAFFS 成为默认文件系统。由于使用广泛,加上 Google 等大公司背书,Ext 4 被认为是成熟稳定的文件系统,适合大多数使用场合,包括 Linux 桌面用户。

作为 Ext 3 文件系统的升级版本,Ext 4 速度和容量都有很大提升,并且 fsck 所需时间大大减少。容量方面,Ext 4 支持最大分区 1EB、最大文件 16TB、最大文件数量 40 亿。作为日志文件系统,Ext 4 文件系统对文件在磁盘中的位置以及磁盘的任何更改做记录,并使用校验和来提高文件系统的可靠性。不过,Ext 4 不支持透明压缩、透明加密、快照等高级功能。

Ext 文件系统的核心开发者 Theodore Ts'o 是一位华裔,目前在 Google 工作,他也是 Linux 内核和 Debian 系统资深开发者。

XFS

XFS 是一种高性能日志文件系统,由 SGI 设计开发,是业界最先进的、最具扩展性的文件系统之一,是目前 CentOS 的默认文件格式。XFS 擅长处理大文件,在大型文件系统上提供非常高的吞吐量和平滑的数据传输,适合拥有海量数据的用户,在企业应用、大数据领域有着广泛应用。

XFS 文件及目录索引采用 B+ 树结构,查询与分配存储空间非常快,性能不受目录及文件数量的限制。XFS 文件系统能连续提供快速的反应时间,以接近裸设备 I/O 的性能存储数据,在大多数场景下整体 IOPS 表现要比 Ext 4 来得更高、更稳定,延迟也更小,在高 I/O 压力下尤其明显。XFS 因其基于分配组 (allocation group) 的设计而特别擅长并行 IO,当该文件系统跨越多个存储设备时,这种设计使得 IO 线程数、文件系统带宽、文件和文件系统大小都具有极大的可伸缩性。

XFS 最大支持 8EB 单个文件。XFS 格式化和挂载非常快,并提供了在线碎片整理功能。XFS 文件系统也有一些不足,例如它不能直接压缩,不支持透明压缩,缺少校验保护等。

ReiserFS

ReiserFS 文件系统曾是 Linux 操作系统上设计最先进、性能最好的文件系统。ReiserFS 作为 SuSE Linux Enterprise 的默认文件系统,曾受到 Novell 公司的力推。

ReiserFS 文件系统使用 B* 树存储文件,查找定位文件非常快,用来处理大量小文件非常有优势,一些场合比 Ext 4 快上数倍。 表现在个人桌面系统,使用 ReiserFS 文件系统能达到更快的开机速度,载入文档、图片也更加快捷。

ReiserFS 的作者 Hans Reiser 是俄裔美国人,他领导的 Namesys 公司致力于开发和维护 ReiserFS 文件系统。本来 ReiserFS 是 Linux 平台最有前途的文件系统,不过 2006 年 Hans Reiser 由于杀妻案入狱,ReiserFS 的开发陷入停滞,错过了最好的发展机会。不过,一小部分开发者仍在进行 ReiserFS 后续版本的开发,Reiser 4 经过全新设计,具备了很多领先的文件系统特性,不过目前还未进入 Linux 内核。

Btrfs

Btrfs 是一种支持写入时复制(COW)的文件系统, 与 ZFS 非常类似,被认为是 Linux 未来最有希望的文件系统,将替代目前广泛使用的 Ext 4 文件系统。Btrfs 也宣称专注于「容错、修复及易于管理」。

Oracle 于 2007 年对外宣布这项计划,并发布源代码,2014 年 8 月发布稳定版。目标是取代 Linux 当时主流的 Ext 3 文件系统,摆脱 Ext 3 的一些限制,特別是单文件大小,文件系统总大小和文件校验,并加入 Ext3 不支持的一些功能,比如可写快照(writable snapshots)、快照的快照(snapshots of snapshots)、内建磁盘阵列(RAID),以及子卷(subvolumes)。

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

另外还有专门为 NAND 闪存设计的 F2FSYAFFS 等文件系统,源自 Solaris 号称终极文件系统的 ZFS(ZFS On Linux)等。

相关推荐

js中arguments详解

一、简介了解arguments这个对象之前先来认识一下javascript的一些功能:其实Javascript并没有重载函数的功能,但是Arguments对象能够模拟重载。Javascrip中每个函数...

firewall-cmd 常用命令

目录firewalldzone说明firewallzone内容说明firewall-cmd常用参数firewall-cmd常用命令常用命令 回到顶部firewalldzone...

epel-release 是什么

EPEL-release(ExtraPackagesforEnterpriseLinux)是一个软件仓库,它为企业级Linux发行版(如CentOS、RHEL等)提供额外的软件包。以下是关于E...

FullGC详解  什么是 JVM 的 GC
FullGC详解 什么是 JVM 的 GC

前言:背景:一、什么是JVM的GC?JVM(JavaVirtualMachine)。JVM是Java程序的虚拟机,是一种实现Java语言的解...

2024-10-26 08:50 citgpt

使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
跨域(CrossOrigin)

1.介绍  1)跨域问题:跨域问题是在网络中,当一个网络的运行脚本(通常时JavaScript)试图访问另一个网络的资源时,如果这两个网络的端口、协议和域名不一致时就会出现跨域问题。    通俗讲...

微服务架构和分布式架构的区别

1、含义不同微服务架构:微服务架构风格是一种将一个单一应用程序开发为一组小型服务的方法,每个服务运行在自己的进程中,服务间通信采用轻量级通信机制(通常用HTTP资源API)。这些服务围绕业务能力构建并...

深入理解与应用CSS clip-path 属性
深入理解与应用CSS clip-path 属性

clip-pathclip-path是什么clip-path 是一个CSS属性,允许开发者创建一个剪切区域,从而决定元素的哪些部分可见,哪些部分会被隐...

2024-10-25 11:51 citgpt

HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
Request.ServerVariables 大全

Request.ServerVariables("Url")返回服务器地址Request.ServerVariables("Path_Info")客户端提供的路...

python操作Kafka

目录一、python操作kafka1.python使用kafka生产者2.python使用kafka消费者3.使用docker中的kafka二、python操作kafka细...

Runtime.getRuntime().exec详解

Runtime.getRuntime().exec详解概述Runtime.getRuntime().exec用于调用外部可执行程序或系统命令,并重定向外部程序的标准输入、标准输出和标准错误到缓冲池。...

promise.all详解 promise.all是干什么的
promise.all详解 promise.all是干什么的

promise.all详解promise.all中所有的请求成功了,走.then(),在.then()中能得到一个数组,数组中是每个请求resolve抛出的结果...

2024-10-24 16:21 citgpt

Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解

取消回复欢迎 发表评论: