FreeBSD 中文手册
FreeBSD 中文社区
  • FreeBSD 中文手册
  • 编辑日志
  • 译者说明
  • FreeBSD 中文手册
  • 概述
  • 前言
    • 致读者
    • 第四版
    • 第三版
    • 第二版(2004)
    • 第一版(2001)
    • 本书的组织结构
    • 本书中使用的一些约定
    • 致谢
  • 第一部分:快速开始
  • 第1章 简介
    • 1.1.概述
    • 1.2.欢迎来到 FreeBSD!
    • 1.3.关于 FreeBSD 项目
  • 第2章 安装 FreeBSD
    • 2.1.概述
    • 2.2.最低硬件要求
    • 2.3.安装前的准备工作
    • 2.4.开始安装
    • 2.5.使用 bsdinstall
    • 2.6.分配磁盘空间
    • 2.7.获取安装文件
    • 2.8.账户、时区、服务和安全
    • 2.9.故障排除
    • 2.10.使用 Live CD
  • 第3章 FreeBSD 基础
    • 3.1.概述
    • 3.2.虚拟控制台和终端
    • 3.3.用户和基本账户管理
    • 3.4.权限
    • 3.5.目录结构
    • 3.6.磁盘结构
    • 3.7.文件系统的挂载与卸载
    • 3.8.进程和守护进程
    • 3.9.Shell
    • 3.10.文本编辑器
    • 3.11.设备和设备节点
    • 3.12.手册页
  • 第4章 安装应用程序:软件包和 Ports
    • 4.1.概述
    • 4.2.软件安装的概述
    • 4.3.寻找所需的应用程序
    • 4.4.使用 pkg 管理二进制包
    • 4.5.使用 Ports
    • 4.6.使用 Poudriere 构建软件包
    • 4.7.安装后的注意事项
    • 4.8.如何处理损坏的 port
  • 第5章 X Window 系统
    • 5.1.概述
    • 5.2.安装 Xorg
    • 5.3.显卡驱动
    • 5.4.Xorg 配置
    • 5.5.在 X11 中使用字体
  • 第6章 FreeBSD 中的 Wayland
    • 6.1.简介
    • 6.2.Wayland 概述
    • 6.3.Wayfire 混成器
    • 6.4.Hikari 混成器
    • 6.5.Sway 混成器
    • 6.6.使用 Xwayland
    • 6.7.使用 VNC 进行远程连接
    • 6.8.Wayland 登录管理器
    • 6.9.实用工具
  • 第7章 网络
    • 7.1.概述
    • 7.2.设置网络
    • 7.3.有线网络
    • 7.4.无线网络
    • 7.5.主机名
    • 7.6.DNS
    • 7.7.故障排除
  • 第二部分:常见任务
  • 第8章 桌面环境
    • 8.1.概述
    • 8.2.桌面环境
    • 8.3.浏览器
    • 8.4.开发工具
    • 8.5.桌面办公应用
    • 8.6.文档阅读器
    • 8.7.财务
  • 第9章 多媒体
    • 9.1.概述
    • 9.2.设置声卡
    • 9.3.音频播放器
    • 9.4.视频播放器
    • 9.5.视频会议
    • 9.6.图像扫描仪
  • 第10章 配置 FreeBSD 内核
    • 10.1.概述
    • 10.2.为什么要构建定制内核
    • 10.3.浏览系统硬件
    • 10.4.配置文件
    • 10.5.构建并安装定制内核
    • 10.6.如果发生了错误
  • 第11章 打印
    • 11.1.快速入门
    • 11.2.连接打印机
    • 11.3.常见的页面描述语言(PDL)
    • 11.4.直接打印
    • 11.5.LPD(行式打印机程序)
    • 11.6.其他打印系统
  • 第12章 Linux 二进制兼容层
    • 12.1.概述
    • 12.2.配置 Linux 二进制兼容层
    • 12.3.Linux 用户空间
    • 12.4.高级主题
  • 第13章 WINE
    • 13.1.概述
    • 13.2.WINE 概述和概念
    • 13.3.在 FreeBSD 上安装 WINE
    • 13.4.在 FreeBSD 上运行第一个 WINE 程序
    • 13.5.配置 WINE 安装程序
    • 13.6.WINE 图形化用户管理界面
    • 13.7.多用户 FreeBSD 与 WINE
    • 13.8.FreeBSD 上的 WINE 常见问题
  • 第三部分:系统管理
  • 第14章 配置与优化
    • 14.1.概述
    • 14.2.配置文件
    • 14.3.管理 FreeBSD 中的服务
    • 14.4.Cron 和 Periodic
    • 14.5.配置系统日志
    • 14.6.电源和资源管理
    • 14.7.添加交换空间
  • 第15章 FreeBSD 的引导过程
    • 15.1.概述
    • 15.2.FreeBSD 的引导过程
    • 15.3.Device Hints
    • 15.4.关机流程
  • 第16章 安全
    • 16.1.概述
    • 16.2.简介
    • 16.3.账户安全
    • 16.4.入侵检测系统(IDS)
    • 16.5.安全等级
    • 16.6.文件标志位
    • 16.7.OpenSSH
    • 16.8.OpenSSL
    • 16.9.Kerberos
    • 16.10.TCP 封装器(TCP Wrapper)
    • 16.11.访问控制列表(ACL)
    • 16.12.Capsicum
    • 16.13.进程记账
    • 16.14.资源限制
    • 16.15.监控第三方安全问题
    • 16.16.FreeBSD 安全公告
  • 第17章 jail 与容器
    • 17.1.概述
    • 17.2.jail 的类型
    • 17.3.主机配置
    • 17.4.传统 jail(厚 jail)
    • 17.5.瘦 jail
    • 17.6.管理 jail
    • 17.7.更新 jail
    • 17.8.jail 资源限制
    • 17.9.jail 管理器与容器
  • 第18章 强制访问控制
    • 18.1.概述
    • 18.2.关键术语
    • 18.3.了解 MAC 标签
    • 18.4.规划安全配置
    • 18.5.可用的 MAC 策略
    • 18.6.用户锁定
    • 18.7.MAC Jail 中的 Nagios
    • 18.8.MAC 框架的故障排除
  • 第19章 安全事件审计
    • 19.1.概述
    • 19.2.关键术语
    • 19.3.审计配置
    • 19.4.使用审计跟踪
  • 第20章 存储
    • 20.1.概述
    • 20.2.添加磁盘
    • 20.3.调整和增加磁盘大小
    • 20.4.USB 存储设备
    • 20.5.创建和使用 CD
    • 20.6.创建和使用 DVD
    • 20.7.创建和使用软盘
    • 20.8.备份的基础知识
    • 20.9.内存盘
    • 20.10.文件系统快照
    • 20.11.磁盘配额
    • 20.12.加密磁盘分区
    • 20.13.加密交换分区
    • 20.14.高可用性存储(HAST)
  • 第21章 GEOM: 模块化磁盘转换框架
    • 21.1.概述
    • 21.2.RAID0——条带
    • 21.3.RAID1——镜像
    • 21.4.RAID3——带有专用奇偶校验的字节级条带
    • 21.5.软件 RAID 设备
    • 21.6.GEOM Gate 网络设备
    • 21.7.为磁盘设备添加卷标
    • 21.8.通过 GEOM 实现 UFS 日志
  • 第22章 Z 文件系统(ZFS)
    • 22.1.是什么使 ZFS 与众不同
    • 22.2.快速入门指南
    • 22.3.zpool 管理
    • 22.4.zfs 管理
    • 22.5.委托管理
    • 22.6.高级主题
    • 22.7.更多资源
    • 22.8.ZFS 特性和术语
  • 第23章 其他文件系统
    • 23.1.概述
    • 23.2.Linux® 文件系统
    • 23.3.Windows® 文件系统
    • 23.4.MacOS® 文件系统
  • 第24章 虚拟化
    • 24.1.概述
    • 24.2.使用 macOS® 上的 Parallels Desktop 安装 FreeBSD
    • 24.3.使用 macOS® 上的 VMware Fusion 安装 FreeBSD
    • 24.4.使用 VirtualBox™ 安装 FreeBSD
    • 24.5.在 FreeBSD 上安装 VirtualBox™
    • 24.6.使用 FreeBSD 上的 QEMU 虚拟化
    • 24.7.使用 FreeBSD 上的 bhyve 虚拟机
    • 24.8.基于 FreeBSD 的 Xen™ 虚拟机
  • 第25章 本地化——i18n/L10n 的使用和设置
    • 25.1.概述
    • 25.2.使用本地化
    • 25.3.寻找 i18n 应用程序
    • 25.4.特定语言的区域配置
  • 第26章 FreeBSD 更新与升级
    • 26.1.概述
    • 26.2.更新 FreeBSD
    • 26.3.更新 Bootcode
    • 26.4.更新文档
    • 26.5.追踪开发分支
    • 26.6.从源代码更新 FreeBSD
    • 26.7.多台机器的追踪
    • 26.8.在非 FreeBSD 主机上进行构建
  • 第27章 DTrace
    • 27.1.概述
    • 27.2.实现上的差异
    • 27.3.开启 DTrace 支持
    • 27.4.启用内核外部模块 DTrace
    • 27.5.使用 DTrace
  • 第28章 USB 设备模式/USB OTG
    • 28.1.概述
    • 28.2.USB 虚拟串行端口
    • 28.3.USB 设备模式网络接口
    • 28.4.USB 虚拟存储设备
  • 第四部分:网络通讯
  • 第29章 串行通信
    • 29.1.概述
    • 29.2.串行术语和硬件
    • 29.3.终端
    • 29.4.拨入服务
    • 29.5.拨出服务
    • 29.6.设置串行控制台
  • 第30章 PPP
    • 30.1.概述
    • 30.2.配置 PPP
    • 30.3.PPP 连接的故障排除
    • 30.4.使用以太网 PPP(PPPoE)
    • 30.5.使用 ATM 上的 PPP (PPPoA)
  • 第31章 电子邮件
    • 31.1.概述
    • 31.2.邮件组件
    • 31.3.DragonFly 邮件代理(DMA)
    • 31.4.Sendmail
    • 31.5.修改邮件传输代理
    • 31.6.邮件用户代理
    • 31.7.高级主题
  • 第32章 网络服务器
    • 32.1.概述
    • 32.2.inetd 超级服务器
    • 32.3.网络文件系统(NFS)
    • 32.4.网络信息系统(NIS)
    • 32.5.轻型目录访问协议(LDAP)
    • 32.6.动态主机设置协议(DHCP)
    • 32.7.域名系统(DNS)
    • 32.8.零配置网络(mDNS/DNS-SD)
    • 32.9.Apache HTTP 服务器
    • 32.10.文件传输协议(FTP)
    • 32.11.用于 Microsoft® Windows® 客户端的文件和打印服务(Samba)
    • 32.12.用 NTP 进行时钟同步
    • 32.13.iSCSI target 和 initiator 的配置
  • 第33章 防火墙
    • 33.1.概述
    • 33.2.防火墙的概念
    • 33.3.PF
    • 33.4.IPFW
    • 33.5.IPFILTER(IPF)
    • 33.6.Blacklistd
  • 第34章 高级网络
    • 34.1.概述
    • 34.2.网关和路由
    • 34.3.虚拟主机
    • 34.4.无线高级身份验证
    • 34.5.无线自组织(Ad-hoc)模式
    • 34.6.USB 网络共享
    • 34.7.蓝牙
    • 34.8.桥接
    • 34.9.链路聚合与故障转移
    • 34.10.使用 PXE 进行无盘操作
    • 34.11.共用地址冗余协议(CARP)
    • 34.12.VLAN
  • 第五部分:附录
  • 附录 A.获取 FreeBSD
    • A.1.镜像站
    • A.2.使用 Git
    • A.3.使用 Subversion
    • A.4.光盘
  • 附录 B.书目
    • B.1.FreeBSD 相关书籍
    • B.2.安全性参考文献
    • B.3.UNIX 历史
    • B.4.期刊与杂志
  • 附录 C.网络资源
    • C.1.网站
    • C.2.邮件列表
    • C.3.Usenet 新闻组
  • 附录 D.OpenPGP 密钥
    • D.1.官方成员
  • 术语表
  • 后记
由 GitBook 提供支持

FreeBSD 中文社区

在本页

这有帮助吗?

在GitHub上编辑
导出为 PDF
  1. 第22章 Z 文件系统(ZFS)

22.8.ZFS 特性和术语

ZFS 不仅仅是一个文件系统,它在本质上是不同的。ZFS 将文件系统和卷管理器的角色结合起来,使得新的存储设备可以添加到一个在线系统中,并且这些新的空间可以立刻在该池中现有的文件系统上使用。通过将传统上分开的角色合并,ZFS 能够克服之前阻止 RAID 组扩展的限制。vdev 是池中的顶级设备,可以是简单的磁盘,也可以是 RAID 阵列,例如镜像或 RAID-Z 阵列。ZFS 文件系统(称为 数据集)每个都可以访问整个池的合并空闲空间。池中已使用的块会减少每个文件系统可用的空间。这种方法避免了大量分区时常见的陷阱,其中空闲空间在各个分区中变得碎片化。

池

存储 池 是 ZFS 的最基本构建模块。一个池由一个或多个 vdev 组成,这些 vdev 是存储数据的底层设备。然后,可以使用池来创建一个或多个文件系统(数据集)或块设备(卷)。这些数据集和卷共享池中的剩余空闲空间。每个池都有一个唯一的名称和 GUID。池上的 ZFS 版本号决定了可用的功能。

vdev 类型

池 (Pool) - 池由一个或多个 vdev 组成,vdev 本身是一个磁盘或多个磁盘组成的 RAID。当使用多个 vdev 时,ZFS 会将数据分布到各个 vdev 上,以提高性能并最大化可用空间。所有 vdev 的大小必须至少为 128 MB。

磁盘 (Disk) - 最基本的 vdev 类型是标准块设备。这可以是整个磁盘(如 /dev/ada0 或 /dev/da0)或一个分区(如 /dev/ada0p3)。在 FreeBSD 上,使用分区而不是整个磁盘不会带来性能损失。这与 Solaris 文档中的推荐不同。

小心: 强烈不建议将整个磁盘作为启动池的一部分,因为这可能导致池无法启动。同样,不应将整个磁盘作为镜像或 RAID-Z vdev 的一部分。由于在启动时无法可靠地确定未分区磁盘的大小,因此没有地方可以放置启动代码。

文件 (File) - 常规文件也可以构成 ZFS 池,这对于测试和实验非常有用。使用文件的完整路径作为设备路径来创建池(zpool create)。

镜像 (Mirror) - 创建镜像时,指定 mirror 关键字,后跟镜像成员设备的列表。镜像由两个或更多设备组成,将所有数据写入所有成员设备。镜像 vdev 将保存与其最小成员相同数量的数据。镜像 vdev 可以承受除一个成员外的所有成员的故障,而不会丢失任何数据。

注意: 要随时将常规单个磁盘 vdev 升级为镜像 vdev,请使用 zpool attach。

RAID-Z - ZFS 使用 RAID-Z,它是标准 RAID-5 的一种变体,提供了更好的奇偶校验分布,并消除了 "RAID-5 写入漏洞",即在意外重启后数据和奇偶校验信息不一致的情况。ZFS 支持三种级别的 RAID-Z,根据阵列中奇偶校验设备的数量和可以故障的磁盘数量,提供不同级别的冗余和可用存储。 在 RAID-Z1 配置中,四个磁盘,每个 1 TB,实际可用存储为 3 TB,并且池可以在一个磁盘故障的情况下以降级模式运行。如果在更换和重新校验故障磁盘之前另一个磁盘掉线,则会丢失所有池数据。 在 RAID-Z3 配置中,八个 1 TB 的磁盘,卷提供 5 TB 的可用空间,并且在三个磁盘故障的情况下仍能运行。Sun™ 建议每个 vdev 最多不超过九个磁盘。如果配置中包含更多磁盘,建议将它们分成多个 vdev,并跨它们条带化池数据。 两个 RAID-Z2 vdev 配置,每个包含 8 个磁盘,类似于 RAID-60 阵列。RAID-Z 组的存储容量大约是最小磁盘大小乘以非奇偶校验磁盘的数量。四个 1 TB 磁盘的 RAID-Z1 配置有效大小约为 3 TB,而八个 1 TB 磁盘的 RAID-Z3 配置提供约 5 TB 的可用空间。

备用 (Spare) - ZFS 具有一种特殊的伪 vdev 类型,用于跟踪可用的热备份。请注意,已安装的热备份不会自动部署;需要手动配置它们来替换故障设备,使用 zfs replace。

事务组(TXG)

事务组(Transaction Groups)是 ZFS 将块更改组合在一起并写入池的方式。事务组是 ZFS 用于确保一致性的原子单位。ZFS 为每个事务组分配一个唯一的 64 位连续标识符。最多可以有三个活动事务组,分别处于以下三种状态之一:

静默 (Quiescing) - 一个短暂的状态,允许任何挂起的操作完成,而不阻塞新的开放事务组的创建。待该事务组中的所有事务完成,事务组会进入最终状态。

自适应替换缓存(ARC)

ZFS 使用自适应替换缓存(ARC),而不是传统的最少最近使用(LRU)缓存。LRU 缓存是一个简单的缓存项目列表,按对象被使用的最近时间排序,将新项目添加到列表头部。当缓存满时,从列表尾部驱逐项目,以为更多活跃对象腾出空间。ARC 由四个列表组成:最常使用(MRU)和最频繁使用(MFU)的对象,以及每个列表的幽灵列表。这些幽灵列表跟踪被驱逐的对象,以防止它们重新加入缓存。这通过避免有偶尔使用历史的对象,增加了缓存命中率。使用 MRU 和 MFU 的另一个优点是,扫描整个文件系统时,MRU 或 LRU 缓存中的所有数据都会被驱逐,以便容纳这些新访问的内容。而在 ZFS 中,还使用了 MFU 来跟踪最常使用的对象,最常访问的块的缓存保持在缓存中。

L2ARC

ZIL

ZIL 通过使用比主存储池中使用的存储设备更快的存储设备(如 SSD)来加速同步事务。当应用程序请求同步写入时(保证数据被写入磁盘,而不是仅仅被缓存以便后续写入),将数据写入更快的 ZIL 存储,然后稍后再刷新到常规磁盘,极大地减少了延迟并提高了性能。像数据库这样的同步工作负载将从仅使用 ZIL 中受益。常规的异步写入(如复制文件)则完全不会使用 ZIL。

写时复制

数据集

文件系统

ZFS 数据集通常用作文件系统。与大多数其他文件系统一样,ZFS 文件系统挂载在系统目录结构中的某个位置,并包含自己的文件和目录,这些文件和目录具有权限、标志以及其他元数据。

卷

ZFS 还可以创建卷,这些卷表现为磁盘设备。卷具有与数据集相似的许多特性,包括写时复制、快照、克隆和校验和。卷对于在 ZFS 上运行其他文件系统格式非常有用,例如 UFS 虚拟化或导出 iSCSI 扩展。

快照

克隆

快照的克隆也是可能的。克隆是快照的可写版本,允许文件系统作为新数据集分叉。与快照一样,克隆最初不消耗任何新空间。当新数据写入克隆时,它会使用新块,从而使克隆的大小增长。当克隆的文件系统或卷中的块被覆盖时,之前块的引用计数会减少。删除克隆所基于的快照是不可能的,因为克隆依赖于它。快照是父级,克隆是子级。克隆可以被提升,从而反转这个依赖关系,使克隆成为父级,原父级成为子级。这个操作不需要新的空间。由于父级和子级使用的空间量会反转,它可能会影响现有的配额和保留。

校验和

  • fletcher2

  • fletcher4

  • sha256

fletcher 算法更快,但 sha256 是一种强加密哈希,具有更低的碰撞概率,但性能稍差。禁用校验和是可能的,但极不推荐。

压缩

每个数据集都有一个压缩属性,默认值为关闭。将此属性设置为可用的压缩算法,将导致对所有写入数据进行压缩。除了节省空间外,读取和写入吞吐量通常会增加,因为需要读取或写入的块较少。

LZ4 - 在 ZFS 池版本 5000(功能标志)中添加,LZ4 现在是推荐的压缩算法。LZ4 在处理可压缩数据时比 LZJB 快约 50%,在处理不可压缩数据时快超过三倍。LZ4 的解压缩速度也比 LZJB 快约 80%。在现代 CPU 上,LZ4 通常可以在每个 CPU 核心上以超过 500 MB/s 的速度进行压缩,以超过 1.5 GB/s 的速度进行解压。

LZJB - 默认的压缩算法。由 Jeff Bonwick(ZFS 的原始创建者之一)创建。LZJB 提供了较好的压缩效果,同时与 GZIP 相比,CPU 开销较小。在未来,默认压缩算法将更改为 LZ4。

GZIP - 在 ZFS 中可用的流行压缩算法。使用 GZIP 的主要优点之一是它可以配置压缩级别。在设置 compress 属性时,管理员可以选择压缩级别,从 gzip1(最低压缩级别)到 gzip9(最高压缩级别)。这使管理员可以控制为节省磁盘空间而交换多少 CPU 时间。

ZLE - 零长度编码是一种特殊的压缩算法,仅压缩连续的零块。当数据集包含大量零块时,这种压缩算法非常有用。

复制

去重

校验和使得在写入数据时能够检测到重复的块。通过去重,现有的相同块的引用计数增加,从而节省存储空间。ZFS 在内存中保持一个去重表(DDT)来检测重复的块。该表包含唯一校验和的列表、这些块的位置以及引用计数。在写入新数据时,ZFS 计算校验和并将其与列表进行比较。当找到匹配项时,ZFS 会使用现有的块。使用 SHA256 校验和算法结合去重提供了一个安全的加密哈希。去重是可调的。如果 dedup 设置为 on,那么匹配的校验和表示数据是相同的。将 dedup 设置为 verify,ZFS 会对数据进行逐字节检查,确保它们确实是相同的。如果数据不相同,ZFS 会记录哈希冲突并将这两个块分别存储。由于 DDT 必须存储每个唯一块的哈希,它会消耗大量内存。一个大致的经验法则是每去重 1 TB 数据需要 5-6 GB 的内存。在没有足够内存将整个 DDT 保存在内存中的情况下,性能会大幅下降,因为 DDT 必须在写入每个新块之前从磁盘读取。去重可以使用 L2ARC 来存储 DDT,提供系统内存和较慢磁盘之间的折衷。考虑改用压缩,它通常能提供几乎相同的空间节省,而不会增加内存消耗。

Scrub

数据集配额

ZFS 提供了快速准确的数据集、用户和组空间核算,以及配额和空间预留。这使管理员能够精细地控制空间分配,并为关键文件系统保留空间。

配额限制数据集及其后代的总大小,包括数据集的快照、子数据集及其快照。

注意: 卷不支持配额,因为 volsize 属性作为隐式配额。

参考配额

引用配额通过强制硬限制来限制数据集可以使用的空间量。这个硬限制只包括数据集本身引用的空间,不包括由后代(如文件系统或快照)使用的空间。

用户配额

用户配额用于限制指定用户使用的空间量。

组配额

组配额限制指定组可以使用的空间量。

数据集保留

任何形式的 reservation 都在以下情况中非常有用,例如在新系统中规划和测试磁盘空间分配的适用性,或确保文件系统上有足够的空间用于音频日志或系统恢复过程和文件。

参考预留

重新同步

在更换故障磁盘时,ZFS 必须将丢失的数据填充到新磁盘中。重新同步 是使用分布在剩余磁盘上的奇偶校验信息来计算并将丢失的数据写入新磁盘的过程。

在线

处于 Online 状态的池或 vdev 其成员设备已连接且完全正常运行。处于 Online 状态的单个设备也在正常工作。

离线

降级

故障

上一页22.7.更多资源下一页23.1.概述

最后更新于27天前

这有帮助吗?

日志 (Log) - ZFS 日志设备,也称为 ZFS 意图日志(),将意图日志从常规池设备转移到专用设备,通常是 SSD。拥有专用日志设备可以提高高同步写入量应用程序(如数据库)的性能。日志设备可以镜像,但不支持 RAID-Z。如果使用多个日志设备,写入将会负载均衡。

缓存 (Cache) - 向池中添加缓存 vdev 将会将缓存的存储添加到 。缓存设备不能镜像。由于缓存设备仅存储现有数据的副本,因此不会有数据丢失的风险。

开放 (Open) - 新的事务组在开放状态下开始,并接受新的写入。如果事务组达到限制,它可能会拒绝新的写入。每个时候总会有一个事务组处于开放状态,但如果达到限制,或者达到 ,事务组会进入下一个状态。

同步 (Syncing) - 将事务组中的所有数据写入稳定存储。这个过程会反过来改变其他数据,如元数据和空间映射,ZFS 也会将它们写入稳定存储。同步过程包含多个阶段。在第一个阶段,所有更改过的数据块会被写入;接下来是元数据,它可能需要多个阶段才能完成。由于为数据块分配空间会生成新的元数据,因此同步状态不能在一个阶段完成,直到没有使用新空间的阶段完成。同步状态还是 synctasks 完成的地方。Synctasks 是管理操作,如创建或销毁快照和数据集,它们完成 uberblock 的更改。待同步状态完成,处于静默状态的事务组会进入同步状态。所有管理功能,如 写入都会作为事务组的一部分。ZFS 会将创建的 synctask 添加到开放事务组,并尽可能快速地将该组推进到同步状态,以减少管理命令的延迟。

L2ARC 是 ZFS 缓存系统的第二级。RAM 存储了主要的 ARC。由于可用 RAM 的数量通常有限,ZFS 还可以使用 。固态硬盘(SSDs)常被用作这些缓存设备,因为它们相比传统的旋转磁盘具有更高的速度和更低的延迟。L2ARC 是完全可选的,但如果有一个,它将提高从 SSD 上缓存文件的读取速度,而不必从常规磁盘中读取。L2ARC 还可以加速 ,因为一个适合放入 L2ARC 但不能放入 RAM 的去重表(DDT)将比必须从磁盘读取的 DDT 快得多。对添加到缓存设备的数据速率的限制可以防止通过额外写入过早损坏 SSD。直到缓存满(驱逐第一个块以腾出空间),写入到 L2ARC 的速度限制为写入限制和加速限制的总和,之后将限制为写入限制。成对的 值控制这些速率限制。 控制每秒写入到缓存的字节数,而 在“加速预热阶段”(写入加速)期间增加此限制。

与传统文件系统不同,ZFS 写入的是一个不同的块,而不是在原地覆盖旧数据。完成写入时,元数据会更新以指向新位置。当发生短写(如系统崩溃或在写文件过程中断电)时,文件的原始全部内容仍然可用,ZFS 会丢弃不完整的写入。这也意味着 ZFS 在意外关机后不需要执行 。

数据集 是 ZFS 文件系统、卷、快照或克隆的通用术语。每个数据集都有一个唯一的名称,格式为 poolname/path@snapshot。池的根目录本身也是一个数据集。子数据集具有类似目录的层次结构名称。例如,mypool/home 作为 home 数据集,是 mypool 的子数据集,并继承其属性。可以通过创建 mypool/home/user 来进一步扩展。这个孙子数据集将继承父数据集和祖父数据集的属性。可以在子数据集上设置属性,覆盖从父数据集和祖父数据集继承的默认值。数据集及其子数据集的管理可以通过 进行。

ZFS 的 (COW)设计允许几乎瞬时地创建一致的快照,并可以使用任意名称。在对数据集进行快照或对父数据集进行递归快照(包括所有子数据集)后,新数据会写入新块,但不会回收旧块作为空闲空间。快照包含原始文件系统版本,而实时文件系统则包含自快照以来所做的任何更改,且不占用其他空间。写入实时文件系统的新数据会使用新块存储这些数据。快照将随着块在实时文件系统中不再使用,而仅在快照中使用而增长。以只读方式挂载这些快照可以恢复以前的文件版本。可以对实时文件系统执行 操作,将其恢复到特定快照,从而撤销自快照以来所做的任何更改。池中的每个块都有一个引用计数器,用于跟踪哪些快照、克隆、数据集或卷使用了该块。当文件和快照被删除时,引用计数减少,当不再引用块时,空闲空间被回收。标记快照为 会导致任何尝试销毁该快照的操作返回 EBUSY 错误。每个快照可以有一个唯一名称的保留。使用 命令移除保留,从而可以删除快照。快照、克隆和回滚可以在卷上操作,但无法独立挂载。

每个块也都有校验和。使用的校验和算法是每个数据集的属性,参见 。每个块的校验和在读取时会透明地进行验证,这使得 ZFS 可以检测到静默损坏。如果读取的数据与预期的校验和不匹配,ZFS 将尝试从任何可用的冗余(如镜像或 RAID-Z)中恢复数据。可以使用 来触发所有校验和的验证。校验和算法包括:

当设置为大于 1 的值时,copies 属性指示 ZFS 在文件系统或 中维护每个块的副本。将此属性设置在重要数据集上可以提供额外的冗余,以便从与校验和不匹配的块中恢复。在没有冗余的池中,副本功能是唯一的冗余形式。副本功能可以从单个坏扇区或其他形式的小故障中恢复,但它不能保护池免受整个磁盘丢失的影响。

与类似 的一致性检查不同,ZFS 使用 scrub。scrub 会读取池中存储的所有数据块,并将它们的校验和与存储在元数据中的已知良好校验和进行验证。定期检查池中存储的所有数据,确保在需要之前恢复任何损坏的块。scrub 在非正常关机后不是必需的,但建议至少每三个月进行一次。ZFS 在正常使用过程中会验证每个块的校验和,但 scrub 会确保检查那些即使是很少使用的块是否有潜在的损坏。ZFS 在归档存储情况下提高了数据安全性。通过调整 的相对优先级,防止 scrub 降低池中其他工作负载的性能。

ZFS 支持不同类型的配额:数据集配额、、 和 。

reservation 属性使得为特定数据集及其后代保证一定的空间成为可能。这意味着,在 storage/home/bob 上设置 10 GB 的 reservation,可以防止其他数据集占用所有的空闲空间,确保至少有 10 GB 的空间为该数据集保留。与常规的 不同,快照和后代所使用的空间不计入 reservation。当对 storage/home/bob 进行快照时,除了 refreservation 部分外,必须有足够的磁盘空间才能成功进行此操作。主数据集的后代不计入 refreservation 的空间,因此不会占用已设置的空间。

refreservation 属性使得可以为特定数据集保留一定的空间,但不包括其后代的数据集。这意味着,在 storage/home/bob 上设置 10 GB 的 reservation,另一个数据集尝试使用空闲空间时,仍会为该数据集保留至少 10 GB 的空间。与常规的 不同,快照和后代数据集所使用的空间不计入该 reservation。例如,如果对 storage/home/bob 进行快照,除了 refreservation 部分外,必须有足够的磁盘空间才能成功完成操作。主数据集的后代不计入 refreservation 空间,因此不会占用已设置的空间。

管理员将单个设备置于 Offline 状态,如果足够的冗余存在以避免将池或 vdev 置于 状态。管理员可能选择将磁盘设置为离线,以便为更换磁盘做准备,或为了更容易识别它。

处于 Degraded 状态的池或 vdev 有一个或多个磁盘丢失或故障。该池仍然可用,但如果其他设备发生故障,池可能变得无法恢复。重新连接丢失的设备或更换故障磁盘后,池将恢复到 状态,前提是重新连接或新设备完成了 过程。

处于 Faulted 状态的池或 vdev 不再可操作,无法访问数据。当丢失或故障的设备数量超过 vdev 中冗余级别时,池或 vdev 进入 Faulted 状态。如果重新连接丢失的设备,池将恢复到 状态。如果冗余不足以弥补故障磁盘的数量,则会丢失池中的数据,需要从备份恢复。

ZIL
L2ARC
vfs.zfs.txg.timeout
快照
缓存 vdevs
去重
sysctl(8)
vfs.zfs.l2arc_write_max
vfs.zfs.l2arc_write_boost
fsck(8)
委派
写时复制
回滚
保留
释放
set
scrub
卷
fsck(8)
vfs.zfs.scrub_delay
引用配额 (refquota)
用户配额
组配额
refreservation
reservation
Faulted
Online
重新同步
Online