跳过导航链接 | |
退出打印视图 | |
Oracle Solaris ZFS 管理指南 Oracle Solaris 10 1/13 Information Library (简体中文) |
1. Oracle Solaris ZFS 文件系统(介绍)
Oracle Solaris ZFS 与传统文件系统之间的差别
4. 安装和引导 Oracle Solaris ZFS 根文件系统
6. 使用 Oracle Solaris ZFS 快照和克隆
7. 使用 ACL 和属性保护 Oracle Solaris ZFS 文件
本节概述了 ZFS 文件系统的新增功能。
Oracle Solaris 10 1/13:zfs 和 zpool 命令具有 help 子命令,可用来提供有关 zfs 和 zpool 子命令及其所支持选项的更多信息。例如:
# zfs help The following commands are supported: allow clone create destroy diff get groupspace help hold holds inherit list mount promote receive release rename rollback send set share snapshot unallow unmount unshare upgrade userspace For more info, run: zfs help <command> # zfs help create usage: create [-p] [-o property=value] ... <filesystem> create [-ps] [-b blocksize] [-o property=value] ... -V <size> <volume>
# zpool help The following commands are supported: add attach clear create destroy detach export get help history import iostat list offline online remove replace scrub set split status upgrade For more info, run: zpool help <command> # zpool help attach usage: attach [-f] <pool> <device> <new-device>
有关更多信息,请参见 zfs(1M) 和 zpool(1M)。
Oracle Solaris 10 1/13:此发行版包含以下 ZFS 快照增强功能:
zfs snapshot 命令具有 snap 别名,该别名提供了此命令的缩写语法。例如:
# zfs snap -r users/home@snap1
zfs diff 命令提供了枚举选项 -e,可标识在两个快照之间添加或修改的所有文件。命令生成的输出中会标识所添加的所有文件,但不提供可能的删除项。例如:
# zfs diff -e tank/cindy@yesterday tank/cindy@now + /tank/cindy/ + /tank/cindy/file.1
还可以使用 -o 选项来标识要显示的选定字段。例如:
# zfs diff -e -o size -o name tank/cindy@yesterday tank/cindy@now + 7 /tank/cindy/ + 206695 /tank/cindy/file.1
有关创建 ZFS 快照的更多信息,请参见第 6 章。
Oracle Solaris 10 1/13:每当在 chmod 操作期间修改文件的 ACL 权限时,aclmode 属性即会修改访问控制列表 (Access Control List, ACL) 的行为。已重新引入了 aclmode 属性,它具有以下属性值:
discard-aclmode 属性为 discard 的文件系统将删除不表示文件模式的所有 ACL 项。这是缺省值。
mask-aclmode 属性为 mask 的文件系统将减少用户或组的权限。除非用户项与文件或目录的所有者具有相同的 UID,否则将减少权限,以使其不会大于组权限位。在这种情况下,减少 ACL 权限,以使其不会大于所有者权限位。如果未执行显式 ACL 集合操作,则 mask 值还会在模式更改之后保留 ACL。
passthrough-aclmode 属性为 passthrough 的文件系统指示除了生成必要的 ACL 项来表示文件或目录的新模式外,不对 ACL 进行其他更改。
有关更多信息,请参见示例 7-13。
Oracle Solaris 10 8/11:在此发行版中,提供了以下新增安装功能:
可以使用文本模式安装方法来通过 ZFS Flash 归档文件安装系统。有关更多信息,请参见示例 4-3。
可以使用 Oracle Solaris Live Upgrade luupgrade 命令安装 ZFS 根 Flash 归档文件。有关更多信息,请参见示例 4-8。
可以使用 Oracle Solaris Live Upgrade 的 lucreate 命令指定单独的 /var 文件系统。有关更多信息,请参见示例 4-5。
Oracle Solaris 10 8/11:在此发行版中,您可以设置在快照流中发送和接收的文件系统属性。通过这些增强功能,可以灵活地将发送流中的文件系统属性应用到接收方文件系统,或确定接收时是否应忽略本地文件系统属性(如 mountpoint 属性值)。
有关更多信息,请参见向 ZFS 快照流应用不同的属性值。
Oracle Solaris 10 8/11:在此发行版中,您可以使用 zfs diff 命令确定 ZFS 快照的差异。
例如,假定创建了以下两个快照:
$ ls /tank/cindy fileA $ zfs snapshot tank/cindy@0913 $ ls /tank/cindy fileA fileB $ zfs snapshot tank/cindy@0914
例如,要确定两个快照之间的差异,请使用类似以下的语法:
$ zfs diff tank/cindy@0913 tank/cindy@0914 M /tank/cindy/ + /tank/cindy/fileB
在输出中,M 表示该目录已经过修改。+ 表示 fileB 存在于较新的快照中。
有关更多信息,请参见确定 ZFS 快照的差异 (zfs diff)。
Oracle Solaris 10 8/11:在此发行版中,提供了以下新增的 ZFS 存储池功能:
可以使用 zpool import -m 命令导入缺少日志的池。有关更多信息,请参见导入缺少日志设备的池。
可以在只读模式下导入池。此功能主要用于池恢复。如果由于底层设备受损而无法访问受损的池,可在只读模式下导入池以恢复数据。有关更多信息,请参见在只读模式下导入池。
在此发行版中创建的 RAID-Z(raidz1、raidz2 或 raidz3)存储池会对某些对延迟敏感的元数据自动进行镜像,以提高读取 I/O 的吞吐量性能。对于升级到池版本 29 或以上版本的现有 RAID-Z 池,将对所有新写入的数据的某些元数据进行镜像。
RAID-Z 池中的镜像元数据不对硬件故障提供额外的防护,这与镜像存储池类似。镜像元数据占用额外的空间,但是 RAID-Z 保护措施与先前发行版中的相同。此增强功能仅出于性能考虑。
Solaris 10 8/11:在此发行版中,您可以使用 sync 属性确定 ZFS 文件系统的同步行为。
缺省同步行为是将所有同步文件系统事务写入意图日志,并刷新所有设备以确保数据稳定。建议不要禁用缺省同步行为。依赖于同步支持的应用程序可能会受影响,并可能发生数据丢失的情况。
sync 属性可以在创建文件系统之前或之后设置。无论何种情况,属性值都将立即生效。例如:
# zfs set sync=always tank/neil
在包含 sync 属性的 Oracle Solaris 发行版中,zil_disable 参数不再可用。
有关更多信息,请参见表 5-1。
Oracle Solaris 10 8/11:在此发行版中,您可以使用 -T 选项提供时间间隔和计数值,使 zpool list 和 zpool status 命令显示额外信息。
此外,zpool status 命令还提供更多的池清理和重新同步信息,如下所示:
重新同步进度报告。例如:
scan: resilver in progress since Thu Jun 7 14:41:11 2012 3.83G scanned out of 73.3G at 106M/s, 0h11m to go 3.80G resilvered, 5.22% done
清理进度报告。例如:
scan: scrub in progress since Thu Jun 7 14:59:25 2012 1.95G scanned out of 73.3G at 118M/s, 0h10m to go 0 repaired, 2.66% done
重新同步完成消息。例如:
resilvered 73.3G in 0h13m with 0 errors on Thu Jun 7 14:54:16 2012
清理完成消息。例如:
scan: scrub repaired 512B in 1h2m with 0 errors on Thu Jun 7 15:10:32 2012
取消正在进行的清理消息。例如:
scan: scrub canceled on Thu Jun 7 15:19:20 MDT 2012
清理和重新同步完成消息在系统重新引导后仍存在
以下语法使用时间间隔和计数选项显示正在进行的池重新同步的信息。您可以使用 -T d 值以标准日期格式显示信息,或使用 -T u 以内部格式显示信息。
# zpool status -T d tank 3 2 Wed Nov 14 15:44:34 MST 2012 pool: tank state: DEGRADED status: One or more devices is currently being resilvered. The pool will continue to function in a degraded state. action: Wait for the resilver to complete. scan: resilver in progress since Wed Nov 14 15:44:34 2012 2.96G scanned out of 4.19G at 189M/s, 0h0m to go 1.48G resilvered, 70.60% done config: NAME STATE READ WRITE CKSUM tank DEGRADED 0 0 0 mirror-0 ONLINE 0 0 0 c0t5000C500335F95E3d0 ONLINE 0 0 0 c0t5000C500335F907Fd0 ONLINE 0 0 0 mirror-1 DEGRADED 0 0 0 c0t5000C500335BD117d0 ONLINE 0 0 0 c0t5000C500335DC60Fd0 DEGRADED 0 0 0 (resilvering) errors: No known data errors
Oracle Solaris 10 8/11:在此发行版中,提供了以下 ACL 增强功能:
除了特殊权限,普通 ACL 不需要 deny 访问控制条目 (Access Control Entry, ACE)。例如,0644、0755 或 0664 模式不需要 deny ACE,但某些模式(如 0705、0060 等)需要 deny ACE。
以前的行为是普通 ACL(如 644)包含 deny ACE。例如:
# ls -v file.1 -rw-r--r-- 1 root root 206663 Jun 14 11:52 file.1 0:owner@:execute:deny 1:owner@:read_data/write_data/append_data/write_xattr/write_attributes /write_acl/write_owner:allow 2:group@:write_data/append_data/execute:deny 3:group@:read_data:allow 4:everyone@:write_data/append_data/write_xattr/execute/write_attributes /write_acl/write_owner:deny 5:everyone@:read_data/read_xattr/read_attributes/read_acl/synchronize :allow
新的行为是普通 ACL(如 644)不包含 deny ACE。例如:
# ls -v file.1 -rw-r--r-- 1 root root 206663 Jun 22 14:30 file.1 0:owner@:read_data/write_data/append_data/read_xattr/write_xattr /read_attributes/write_attributes/read_acl/write_acl/write_owner /synchronize:allow 1:group@:read_data/read_xattr/read_attributes/read_acl/synchronize:allow 2:everyone@:read_data/read_xattr/read_attributes/read_acl/synchronize :allow
在继承过程中,ACL 不再被拆分成多个 ACE 以尝试保留未经修改的原始权限。而是根据需要修改权限以强制进入文件创建模式。
aclinherit 属性行为包括当属性设置为 restricted 时减少权限,这意味着继承过程中不再将 ACL 拆分成多个 ACE。
一种新的权限模式计算规则,即,如果 ACL 的 user ACE 同时也是文件所有者,则这些权限将包括在权限模式计算中。如果 group ACE 是文件的组所有者,将适用同样的规则。
有关更多信息,请参见第 7 章。
Oracle Solaris 10 9/10:在此发行版中,您可以使用 zpool split 命令分割镜像的存储池,从原镜像池中分离一个或多个磁盘,创建另一个完全相同的池。
有关更多信息,请参见通过分割镜像 ZFS 存储池创建新池。
Oracle Solaris 10 9/10:在此发行版中,每个 ZFS 存储池都有一个关联的进程 zpool-poolname。此进程中的线程是用来处理与池相关的 I/O 任务(如压缩和校验和验证)的池 I/O 处理线程。此进程的作用是使各存储池的 CPU 利用情况具有可见性。
使用 ps 和 prstat 命令可以查看有关这些运行进程的信息。这些进程仅在全局区域中可用。有关更多信息,请参见 SDC(7)。
Oracle Solaris 10 9/10:在此发行版中,使用较大磁盘替换池中的磁盘时会提供系统事件或 sysevent。ZFS 的功能已得到增强,可以识别这些事件,并根据磁盘的新大小调整池,具体取决于 autoexpand 属性的设置。可以使用 autoexpand 池属性允许或禁止在较大磁盘替换了较小磁盘时进行自动池扩展。
这些增强功能使您可以增大池的大小,而不必导出和导入池或重新引导系统。
例如,对 tank 池启用自动 LUN 扩展功能。
# zpool set autoexpand=on tank
或者,可以在启用 autoexpand 属性的情况下创建池。
# zpool create -o autoexpand=on tank c1t13d0
缺省情况下,autoexpand 属性是禁用的,以便您可以决定,当较大磁盘替换较小磁盘时是否要扩展池的大小。
使用 zpool online - e 命令也可以扩展池的大小。例如:
# zpool online -e tank c1t6d0
或者,您可以在附加了较大磁盘或使其变为可用之后使用 zpool replace 命令重置 autoexpand 属性。例如,下例利用一个 8-GB 磁盘 (c0t0d0) 创建了一个池。8-GB 磁盘被一个 16-GB 磁盘 (c1t13d0) 替换,但直到启用 autoexpand 属性之后,池大小才会扩展。
# zpool create pool c0t0d0 # zpool list NAME SIZE ALLOC FREE CAP HEALTH ALTROOT pool 8.44G 76.5K 8.44G 0% ONLINE - # zpool replace pool c0t0d0 c1t13d0 # zpool list NAME SIZE ALLOC FREE CAP HEALTH ALTROOT pool 8.44G 91.5K 8.44G 0% ONLINE - # zpool set autoexpand=on pool # zpool list NAME SIZE ALLOC FREE CAP HEALTH ALTROOT pool 16.8G 91.5K 16.8G 0% ONLINE -
另一种不启用 autoexpand 属性即可扩展磁盘的方法是使用 zpool online -e 命令,即使设备已经处于联机状态。例如:
# zpool create tank c0t0d0 # zpool list tank NAME SIZE ALLOC FREE CAP HEALTH ALTROOT tank 8.44G 76.5K 8.44G 0% ONLINE - # zpool replace tank c0t0d0 c1t13d0 # zpool list tank NAME SIZE ALLOC FREE CAP HEALTH ALTROOT tank 8.44G 91.5K 8.44G 0% ONLINE - # zpool online -e tank c1t13d0 # zpool list tank NAME SIZE ALLOC FREE CAP HEALTH ALTROOT tank 16.8G 90K 16.8G 0% ONLINE -
此发行版中的其他设备替换增强功能包括:
在先前的发行版中,如果替换磁盘的大小与现有磁盘稍有不同,ZFS 就无法替换现有磁盘或附加新磁盘。在此发行版中,只要池未满,就可以用几乎同样大小的新磁盘替换现有磁盘或附加新磁盘。
在此发行版中,扩展池大小无需重新引导系统或者导出并导入一个池。如前所述,可以启用 autoexpand 属性或者使用 zpool online -e 命令扩展池的大小。
有关替换设备的更多信息,请参见替换存储池中的设备。
Solaris 10 10/09:在此发行版中,您可以设置 JumpStart 配置文件来标识 ZFS 根池的 Flash 归档文件。有关更多信息,请参见安装 ZFS 根文件系统(Oracle Solaris Flash 归档文件安装)。
Solaris 10 5/09:此发行版扩展了以下支持:使用 Oracle Solaris Live Upgrade 在 ZFS 环境中迁移区域。有关更多信息,请参见使用 Oracle Solaris Live Upgrade 迁移或升级具有区域的系统(最低 Solaris 10 5/09)。
有关此发行版的已知问题列表,请参见《Solaris 5 10/09 发行说明》。
Solaris 10 10/08:此发行版提供了安装并引导 ZFS 根文件系统的功能。您可以使用初始安装选项或 JumpStart 功能来安装 ZFS 根文件系统。或者,可以使用 Oracle Solaris Live Upgrade 功能将 UFS 根文件系统迁移到 ZFS 根文件系统。此外,还提供了对交换和转储设备的 ZFS 支持。有关更多信息,请参见第 4 章。
有关此发行版的已知问题列表,请参见《Solaris 10 10/08 发行说明》。
Solaris 10 6/06 发行版:ZFS 管理控制台是一个基于 Web 的 ZFS 管理工具,允许您执行以下管理任务:
创建新存储池。
为现有池添加功能。
将存储池移动(导出)到另一个系统。
导入以前导出的存储池,使其可在另一个系统中使用。
查看有关存储池的信息。
创建文件系统。
创建卷。
创建文件系统或卷的快照。
将文件系统回滚到以前的快照。
通过安全 Web 浏览器访问以下网址,可以访问 ZFS 管理控制台:
https://system-name:6789/zfs
如果键入了适当的 URL 但无法访问 ZFS 管理控制台,则表明可能未启动服务器。要启动服务器,请运行以下命令:
# /usr/sbin/smcwebserver start
如果希望服务器在系统引导时自动启动,请运行以下命令:
# /usr/sbin/smcwebserver enable
注 - 不能使用 Solaris Management Console (smc) 管理 ZFS 存储池或文件系统。