Oracle Solaris ZFS 管理指南

从 ZFS 根文件系统引导

基于 SPARC 和基于 x86 的系统都使用新型的引导方式,即通过引导归档文件进行引导,引导归档文件是一个文件系统映像,该映像中包含进行引导时所需的文件。从 ZFS 根文件系统引导系统时,将会在选择用来进行引导的根文件系统中解析引导归档文件和内核文件的路径名。

引导系统进行安装时,在整个安装过程中,RAM 磁盘用于根文件系统。

从 ZFS 文件系统引导不同于从 UFS 文件系统引导,因为对于 ZFS,引导设备说明符标识存储池,而不是单个根文件系统。存储池可能包含多个可引导的数据集或 ZFS 根文件系统。从 ZFS 引导时,必须指定引导设备和由该引导设备标识的池中的根文件系统。

缺省情况下,选择用来进行引导的数据集是由池的 bootfs 属性标识的。通过在 boot -Z 命令中指定备用可引导数据集可以覆盖此缺省选择。

从镜像 ZFS 根池中的备用磁盘引导

您可以在安装系统时创建镜像 ZFS 根池,也可以在安装后通过附加磁盘来创建镜像 ZFS 根池。有关更多信息,请参见:

请查看以下有关镜像 ZFS 根池的已知问题:

SPARC:从 ZFS 根文件系统引导

在具有多个 ZFS BE 的基于 SPARC 的系统上,可以通过使用 luactivate 命令从任何 BE 引导。

在 Solaris OS 安装和 Oracle Solaris Live Upgrade 过程中,将会通过 bootfs 属性自动指定 ZFS 根文件系统。

一个池中可能存在多个可引导的数据集。缺省情况下,/pool-name/boot/menu.lst 文件中的可引导数据集项由池的 bootfs 属性来标识。但是,menu.lst 项可以包含 bootfs 命令,该命令可指定池中的备用数据集。这样,menu.lst 文件就可以包含池中多个根文件系统的项。

当系统中安装了 ZFS 根文件系统或迁移到 ZFS 根文件系统时,类似如下的项会添加到 menu.lst 文件:


title zfsBE
bootfs rpool/ROOT/zfsBE
title zfs2BE
bootfs rpool/ROOT/zfs2BE

创建新 BE 时,将会自动更新 menu.lst 文件。

在基于 SPARC 的系统上,提供了两个新的引导选项:


示例 5–8 SPARC:从特定的 ZFS 引导环境引导

如果系统的引导设备上的 ZFS 存储池中有多个 ZFS BE,您可以使用 luactivate 命令指定缺省 BE。

例如,以下 ZFS BE 可用,如 lustatus 输出所述:


# lustatus
Boot Environment           Is       Active Active    Can    Copy      
Name                       Complete Now    On Reboot Delete Status    
-------------------------- -------- ------ --------- ------ ----------
zfsBE                      yes      no     no        yes    -         
zfs2BE                     yes      yes    yes       no     -

如果基于 SPARC 的系统上有多个 ZFS BE,您可以使用 boot -L 命令从非缺省 BE 引导。然而,从 boot -L 会话引导的 BE 不会向缺省 BE 一样重置,bootfs 属性也不会进行更新。如果要使从 boot -L 会话引导的 BE 成为缺省 BE,必须使用 luactivate 命令激活它。

例如:


ok boot -L
Rebooting with command: boot -L
Boot device: /pci@7c0/pci@0/pci@1/pci@0,2/LSILogic,sas@2/disk@0  File and args: -L

1 zfsBE
2 zfs2BE
Select environment to boot: [ 1 - 2 ]: 1
To boot the selected entry, invoke:
boot [<root-device>] -Z rpool/ROOT/zfsBE

Program terminated
ok boot -Z rpool/ROOT/zfsBE


示例 5–9 SPARC:在故障安全模式下引导 ZFS 文件系统

在基于 SPARC 的系统上,您可以按如下方式从位于 /platform/`uname -i`/failsafe 的故障安全归档文件引导:


ok boot -F failsafe

要从特定的 ZFS 可引导数据集引导故障安全归档文件,请使用类似如下的语法:


ok boot -Z rpool/ROOT/zfsBE -F failsafe

x86:从 ZFS 根文件系统引导

在 Solaris OS 安装过程中或执行 Oracle Solaris Live Upgrade 操作期间,以下项会添加到 /pool-name/boot/grub/menu.lst 文件以自动引导 ZFS:


title Solaris 10 9/10  X86
findroot (rootfs0,0,a)
kernel$ /platform/i86pc/multiboot -B $ZFS-BOOTFS
module /platform/i86pc/boot_archive
title Solaris failsafe
findroot (rootfs0,0,a)
kernel /boot/multiboot kernel/unix -s -B console=ttya
module /boot/x86.miniroot-safe

如果由 GRUB 标识为引导设备的设备包含 ZFS 存储池,则 menu.lst 文件用于创建 GRUB 菜单。

在具有多个 ZFS BE 的基于 x86 的系统上,您可以从 GRUB 菜单中选择 BE。如果与该菜单项对应的根文件系统为 ZFS 数据集,则会添加以下选项:


-B $ZFS-BOOTFS

示例 5–10 x86:引导 ZFS 文件系统

从 ZFS 文件系统引导系统时,根设备由 GRUB 菜单项中的 -kernelmodule 行上的 B $ZFS-BOOTFS 引导参数指定。该参数(与由 -B 选项指定的所有参数类似)由 GRUB 传递给内核。例如:



title Solaris 10 9/10  X86
findroot (rootfs0,0,a)
kernel$ /platform/i86pc/multiboot -B $ZFS-BOOTFS
module /platform/i86pc/boot_archive
title Solaris failsafe
findroot (rootfs0,0,a)
kernel /boot/multiboot kernel/unix -s -B console=ttya
module /boot/x86.miniroot-safe

示例 5–11 x86:在故障安全模式下引导 ZFS 文件系统

x86 故障安全归档文件为 /boot/x86.miniroot-safe,可以通过从 GRUB 菜单选择 Solaris 故障安全项来引导。例如:


title Solaris failsafe
findroot (rootfs0,0,a)
kernel /boot/multiboot kernel/unix -s -B console=ttya
module /boot/x86.miniroot-safe

解决妨碍成功引导的 ZFS 挂载点问题 (Solaris 10 10/08)

更改活动引导环境的最佳方法是使用 luactivate 命令。如果由于错误的修补程序或配置错误而导致引导活动环境失败,则从其他环境引导的唯一方法是在引导时选择该环境。您可以在基于 x86 的系统上从 GRUB 菜单中选择备用 BE,或在基于 SPARC 的系统上从 PROM 中显式引导备用 BE。

由于 Solaris 10 10/08 发行版 Oracle Solaris Live Upgrade 功能中的错误,非活动引导环境可能无法引导,因为引导环境中的 ZFS 数据集或区域的 ZFS 数据集有无效的挂载点。如果 BE 有单独的 /var 数据集,则上述错误还会阻止该 BE 挂载。

如果区域数据集有无效的挂载点,通过下列步骤可以更正该挂载点。

Procedure如何解决 ZFS 挂载点问题

  1. 从故障安全归档文件引导系统。

  2. 导入池。

    例如:


    # zpool import rpool
    
  3. 查找不正确的临时挂载点。

    例如:


    # zfs list -r -o name,mountpoint rpool/ROOT/s10u6
        
        NAME                               MOUNTPOINT
        rpool/ROOT/s10u6                   /.alt.tmp.b-VP.mnt/
        rpool/ROOT/s10u6/zones             /.alt.tmp.b-VP.mnt//zones
        rpool/ROOT/s10u6/zones/zonerootA   /.alt.tmp.b-VP.mnt/zones/zonerootA

    根 BE (rpool/ROOT/s10u6) 的挂载点应为 /

    如果由于 /var 挂载问题而导致引导失败,请为 /var 数据集查找类似不正确的临时挂载点。

  4. 重置 ZFS BE 及其数据集的挂载点。

    例如:


    # zfs inherit -r mountpoint rpool/ROOT/s10u6
    # zfs set mountpoint=/ rpool/ROOT/s10u6
    
  5. 重新引导系统。

    当提供选项来引导特定的引导环境时(在 GRUB 菜单中或 OpenBoot PROM 提示符下),请选择刚刚更正其挂载点的引导环境。

在 ZFS 根环境中进行引导以恢复系统

如果您需要引导系统,以解决根密码丢失或类似问题,请使用以下过程。

需要引导故障安全模式或从备用介质引导,具体取决于错误的严重程度。一般而言,引导故障安全模式可以解决根密码丢失或未知问题。

如果您需要恢复根池或根池快照,请参见恢复 ZFS 根池或根池快照

Procedure如何引导 ZFS 故障安全模式

  1. 引导故障安全模式。

    在 SPARC 系统上:


    ok boot -F failsafe
    

    在 x86 系统上,从 GRUB 提示符下选择故障安全模式。

  2. 提示时,将 ZFS BE 挂载于 /a


    .
    .
    .
    ROOT/zfsBE was found on rpool.
    Do you wish to have it mounted read-write on /a? [y,n,?] y
    mounting rpool on /a
    Starting shell.
  3. 变更到 /a/etc 目录。


    # cd /a/etc
    
  4. 如有必要,设置 TERM 类型。


    # TERM=vt100
    # export TERM
  5. 修正 passwdshadow 文件。


    # vi shadow
    
  6. 重新引导系统。


    # init 6
    

Procedure如何从备用介质引导 ZFS

如果某个问题妨碍系统成功引导,或者发生其它严重问题,您将需要从网络安装服务器或者 Solaris 安装 CD 引导,导入根池,挂载 ZFS BE,并尝试解决问题。

  1. 从安装 CD 或者网络引导。

    • SPARC:


      ok boot cdrom -s 
      ok boot net -s
      

      如果您未使用 -s 选项,则需要退出安装程序。

    • x86:选择网络引导或者从本地 CD 引导选项。

  2. 导入根池并指定备用挂载点。例如:


    # zpool import -R /a rpool
    
  3. 挂载 ZFS BE。例如:


    # zfs mount rpool/ROOT/zfsBE
    
  4. /a 目录访问 ZFS BE 内容。


    # cd /a
    
  5. 重新引导系统。


    # init 6