ZFS 由 Sun Microsystems 开发,后来被 Oracle 收购,是当今最流行的存储系统之一。它通过组合文件系统和逻辑卷管理器 (LVM) 创建,具有出色的企业级特性,如数据压缩、写时复制、数据冗余、快照、错误检查等。Sun 被 Oracle 收购后,ZFS 被恢复为闭源。作为回应,OpenZFS 于 2013 年诞生,旨在以开源方式继续维护 ZFS。本文将详细介绍如何在 CentOS 7 上安装和配置 ZFS 文件系统,并解释 ZFS 的底层实现及关键术语。
关键术语
数据压缩
ZFS 支持多种压缩算法,如 LZ4、GZIP 等,通过在存储数据前对其进行压缩来节省空间和提升性能。
写时复制 (Copy-On-Write)
ZFS 在写入数据时不会覆盖现有的数据块,而是将更改写入新块,并更新指向这些块的指针。这确保了数据的一致性和完整性,即使在写入过程中系统崩溃也不会导致数据损坏。
数据冗余
ZFS 支持多种数据冗余模式,如镜像 (mirroring) 和 RAID-Z,通过在多个磁盘上存储数据副本来提高数据的可靠性和可用性。
快照
快照是文件系统在某个时间点的只读副本,可以快速创建并几乎不占用额外空间,适用于备份和数据恢复。
错误检查
ZFS 通过对所有数据进行校验和计算来检测和纠正数据错误,确保存储的数据始终是正确的。
1. 安装 ZFS 存储库
首先,我们需要检查当前安装的 CentOS 版本:
[root@localhost ~]# cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
在验证 CentOS 版本后,使用以下命令添加 ZFS On Linux 的 repo:
[root@localhost ~]# yum install https://zfsonlinux.org/epel/zfs-release-2-3.el7.noarch.rpm -y
2. 安装 ZFS
配置完成存储库后,使用如下命令安装 ZFS:
[root@localhost ~]# yum install kernel-devel zfs -y
安装完成后,需要重启服务器加载 ZFS 模块:
[root@localhost ~]# reboot
3. 检查 ZFS 内核模块
重启完成后,用如下命令查看 ZFS 模块是否已经加载:
[root@localhost ~]# lsmod | grep zfs
如果模块已经正确加载,应该看到如下输出信息:
[root@localhost ~]# lsmod | grep zfs
zfs 4261742 0
zunicode 331170 1 zfs
zzstd 468972 1 zfs
zlua 155622 1 zfs
zcommon 94285 1 zfs
znvpair 94388 2 zfs,zcommon
zavl 15698 1 zfs
icp 305871 1 zfs
spl 100846 6 icp,zfs,zavl,zzstd,zcommon,znvpair
如果由于某些原因模块没有加载,可以使用以下命令手动加载它并再次检查:
[root@localhost ~]# modprobe zfs
4. 创建 ZFS 存储池
假设有两个磁盘 /dev/sdb
和 /dev/sdc
,可以创建一个名为 tank
的存储池:
[root@localhost ~]# sudo zpool create tank /dev/sdb /dev/sdc
创建成功后,可以使用以下命令检查存储池状态:
[root@localhost ~]# sudo zpool status
在存储池 tank
中创建一个文件系统 tank/data
:
[root@localhost ~]# sudo zfs create tank/data
5. 使用快照
基于上一步存储池中的文件系统,可以通过如下命令完成快照操作:
# 1. 创建快照
sudo zfs snapshot tank/data@my_snapshot
# 2. 列出快照
sudo zfs list -t snapshot
# 3. 回滚到快照
sudo zfs rollback tank/data@my_snapshot
# 4. 删除快照
sudo zfs destroy tank/data@my_snapshot
6. 启用压缩
可以在创建文件系统时启用压缩,或者在已有文件系统上启用压缩:
[root@localhost ~]# sudo zfs set compression=on tank/data
# 检查压缩状态
[root@localhost ~]# sudo zfs get compression tank/data
7. 常用命令
# 1. 查询存储池状态
[root@localhost ~]# zpool status
# 2. 查看 ZFS 数据集的列表
[root@localhost ~]# zfs list
# 3. 导入在其他服务器上创建的 ZFS 池
[root@localhost ~]# zpool import pool_name
# 4. 检查 ZFS 内核模块
[root@localhost ~]# lsmod | grep zfs
# 5. 从内核添加 ZFS 模块
[root@localhost ~]# sudo modprobe -v zfs
总结
通过以上步骤,您已经成功在 CentOS 7 上安装并配置了 ZFS 文件系统。ZFS 强大的功能和高可靠性使其成为许多企业和高性能存储解决方案的首选。希望这篇指南能帮助您更好地了解和使用 ZFS 文件系统。
参考资料
通过这些资料,您可以进一步了解 ZFS 的实现细节和使用方法。