本章提供有關從 UFS 根 (/) 檔案系統遷移至安裝非全域區域之系統上的 ZFS 根池的逐步說明。在 UFS 檔案系統中,沒有任何非全域區域位於共用檔案系統上。
lucreate 指令會從 UFS 根 (/) 檔案系統建立 ZFS 根池的啟動環境。在 lucreate 作業之前,ZFS 根池必須存在,且必須使用磁碟片段 (而非整個磁碟) 加以建立,才能升級及啟動。此程序顯示與 UFS 根 (/) 檔案系統相關聯的現有非全域區域如何複製到 ZFS 根池中的新啟動環境。
在下列範例中,現有非全域區域 myzone 在 UFS 根 (/) 檔案系統中具有其非全域區域根。區域 zzone 在現有 ZFS 儲存池 pool 中,於 ZFS 檔案系統中有其區域根。使用 Solaris Live Upgrade 將 UFS 啟動環境 c2t2d0s0 遷移至 ZFS 啟動環境 zfs2BE。基於 UFS 的 myzone 區域會遷移至新 ZFS 儲存池 mpool,即 Solaris Live Upgrade 作業之前所建立的儲存池。基於 ZFS 的非全域區域 zzone 會複製 (但仍會保留在 ZFS 池 pool 中) 並遷移至新啟動環境 zfs2BE。
在第一次執行 Solaris Live Upgrade 時,請完成下列步驟。
使用 Solaris Live Upgrade 建立新 ZFS 啟動環境,至少需要安裝 Solaris 10 10/08 發行版本。舊版沒有 ZFS 和 Solaris Live Upgrade 軟體可執行作業。
如有必要,請移除系統上現有的 Solaris Live Upgrade 套裝軟體。如果您要升級至新發行版本,則必須從該發行版本安裝套裝軟體。
三種 Solaris Live Upgrade 套裝軟體 SUNWluu、SUNWlur 和 SUNWlucfg 組成了使用 Solaris Live Upgrade 進行升級所需的軟體。這些套裝軟體包含現有軟體、新功能和錯誤修正。若您在使用 Solaris Live Upgrade 前未移除現有套裝軟體並在系統上安裝新套裝軟體,則升級至目標發行版本時會失敗。
# pkgrm SUNWlucfg SUNWluu SUNWlur |
從您要升級的發行版本安裝新的 Solaris Live Upgrade 套裝軟體。如需相關說明,請參閱安裝 Solaris Live Upgrade。
安裝或執行 Solaris Live Upgrade 之前,必須安裝下列修補程式。這些修補程式可確保您有此發行版本中的所有最新錯誤修正程式和新功能。
請參閱SunSolve,以確定您有最近更新的修補程式清單。在 SunSolve 網站上搜尋資訊文件 206844 (以前為 72099)。
成為超級使用者,或者假定一個對等身份。
如果您要在本機磁碟上儲存修補程式,請建立如 /var/tmp/lupatches 的目錄,然後將修補程式下載至該目錄中。
請從 SunSolve 網站取得修補程式清單。
變更至修補程式目錄。
# cd /var/tmp/lupatches |
使用 patchadd 指令安裝修補程式。
# patchadd patch_id |
patch_id 為修補程式編號。請以空格分隔多個修補程式名稱。
您必須依照資訊文件 206844 中所指定的順序套用修補程式。
如有必要,請重新啟動系統。部分修補程式需要重新啟動後才會生效。
僅限 x86: 必須重新啟動系統,否則 Solaris Live Upgrade 會失敗。
# init 6 |
建立 ZFS 根池。
ZFS 根池必須位於單一磁碟片段上,才能啟動和升級。
# zpool create rpool c3t0d0s0 |
在此範例中,要建立的新 ZFS 名稱為 rpool。該池會建立於可啟動磁碟片段 c3t0d0s0 上。
如需有關建立新根池的資訊,請參閱「Solaris ZFS Administration Guide」。
將 USF 根 (/) 檔案系統遷移至新的 ZFS 根池。
# lucreate [-c ufsBE] -n new-zfsBE -p rpool |
將名稱 ufsBE 指定給目前的 UFS 啟動環境。此選項不是必要選項,它僅在建立第一個啟動環境時使用。如果您是首次執行 lucreate 指令,並省略了 -c 選項,則軟體會為您建立一個預設名稱。
將名稱 new-zfsBE 指定給要建立的啟動環境。該名稱在此系統上必須是唯一的。
將新建立的 ZFS 根 (/) 檔案系統置於 rpool 所定義的 ZFS 根池中。
所有非共用的非全域區域都會與重要檔案系統一起複製到新啟動環境。建立新 ZFS 啟動環境可能需要一些時間。UFS 檔案系統資料將複製到 ZFS 根池。在建立非使用中的啟動環境後,您可以使用 luupgrade 或 luactivate 指令,升級或啟動新的 ZFS 啟動環境。
(可選擇) 驗證啟動環境。
lustatus 指令會報告啟動環境的建立是否完整且可啟動。
# lustatus boot environment Is Active Active Can Copy Name Complete Now OnReboot Delete Status ------------------------------------------------------------------------ ufsBE yes yes yes no - new-zfsBE yes no no yes - |
(可選擇) 驗證系統上的基本資料集資訊。
list 指令會顯示系統上所有資料集的名稱。在此範例中,rpool 為 ZFS 池的名稱,new-zfsBE 為新建立的 ZFS 啟動環境名稱。
# zfs list NAME USED AVAIL REFER MOUNTPOINT rpool 9.29G 57.6G 20K /rpool rpool/ROOT 5.38G 57.6G 18K /rpool/ROOT rpool/ROOT/new-zfsBE 5.38G 57.6G 551M /tmp/.alt.luupdall.110034 rpool/dump 1.95G - 1.95G - rpool/swap 1.95G - 1.95G - |
在執行 luactivate 指令之前,所列出的新啟動環境掛載點都是暫時的掛載點。/dump 和 /swap 磁碟區不會與原始 UFS 啟動環境共用,但是會在 ZFS 根池中與根池中的啟動環境共用。
在下列範例中,現有非全域區域 myzone 在 UFS 根 (/) 檔案系統中具有其非全域區域根。區域 zzone 在現有 ZFS 儲存池 pool 中,於 ZFS 檔案系統中有其區域根。使用 Solaris Live Upgrade 將 UFS 啟動環境 c2t2d0s0 遷移至 ZFS 啟動環境 zfs2BE。基於 UFS 的 myzone 區域會遷移至新 ZFS 儲存池 mpool,即 Solaris Live Upgrade 作業之前所建立的儲存池。基於 ZFS 的非全域區域 zzone 會複製 (但仍會保留在 ZFS 池 pool 中) 並遷移至新啟動環境 zfs2BE。
# zoneadm list -iv ID NAME STATUS PATH BRAND IP 0 global running / native shared - myzone installed /zones/myzone native shared - zzone installed /pool/zones native shared # zpool create mpool mirror c3t0d0s0 c4td0s0 # lucreate -c c1t2d0s0 -n zfs2BE -p mpool Analyzing system configuration. No name for current boot environment. Current boot environment is named <c1t2d0s0>. Creating initial configuration for primary boot environment <c1t2d0s0>. The device </dev/dsk/c1t2d0s0> is not a root device for any boot environment; cannot get BE ID. PBE configuration successful: PBE name <c1t2d0s0> PBE Boot Device </dev/dsk/c1t2d0s0>. Comparing source boot environment <c1t2d0s0> file systems with the file system(s) you specified for the new boot environment. Determining which file systems should be in the new boot environment. Updating boot environment description database on all BEs. Updating system configuration files. The device </dev/dsk/c1t0d0s0> is not a root device for any boot environment; cannot get BE ID. Creating configuration for boot environment <zfsBE>. Source boot environment is <c1t2d0s0>. Creating boot environment <zfsBE>. Creating file systems on boot environment <zfsBE>. Creating <zfs> file system for </> in zone <global> on <rpool/ROOT/zfsBE>. Populating file systems on boot environment <zfsBE>. Checking selection integrity. Integrity check OK. Populating contents of mount point </>. Copying. Creating shared file system mount points. Creating compare databases for boot environment <zfsBE>. Creating compare database for file system </>. Making boot environment <zfsBE> bootable. Creating boot_archive for /.alt.tmp.b-cBc.mnt updating /.alt.tmp.b-cBc.mnt/platform/sun4u/boot_archive Population of boot environment <zfsBE> successful. Creation of boot environment <zfsBE> successful. |
當 lucreate 作業完成,請使用 lustatus 指令檢視啟動環境狀態,如此範例中所示。
# lustatus Boot Environment Is Active Active Can Copy Name Complete Now On Reboot Delete Status -------------------------- -------- ------ --------- ------ ---------- c1t2d0s0 yes yes yes no - zfsBE yes no no yes - |
# zoneadm list -iv ID NAME STATUS PATH BRAND IP 0 global running / native shared - myzone installed /zones/myzone native shared - zzone installed /pool/zones native shared |
接下來,請使用 luactivate 指令啟動新 ZFS 啟動環境。例如:
# luactivate zfsBE ********************************************************************** The target boot environment has been activated. It will be used when you reboot. NOTE: You MUST NOT USE the reboot, halt, or uadmin commands. You MUST USE either the init or the shutdown command when you reboot. If you do not use either init or shutdown, the system will not boot using the target BE. ********************************************************************** In case of a failure while booting to the target BE, the following process needs to be followed to fallback to the currently working boot environment: 1. Enter the PROM monitor (ok prompt). 2. Change the boot device back to the original boot environment by typing: setenv boot-device /pci@1f,0/pci@1/scsi@4,1/disk@2,0:a 3. Boot to the original boot environment by typing: boot ********************************************************************** Modifying boot archive service Activation of boot environment <ZFSbe> successful. |
將系統重新啟動至 ZFS BE。
# init 6 # svc.startd: The system is coming down. Please wait. svc.startd: 79 system services are now being stopped. . . . |
確認新啟動環境和遷移區域的狀態,如此範例中所示。
# lustatus Boot Environment Is Active Active Can Copy Name Complete Now On Reboot Delete Status -------------------------- -------- ------ --------- ------ ---------- c1t2d0s0 yes yes yes no - zfsBE yes no no yes - |
如果要轉至備用 UFS 啟動環境,則必須再次匯入在 ZFS 啟動環境中建立的所有 ZFS 儲存池,因為在 UFS 啟動環境中不會自動提供這些儲存池。當您切換回 UFS 啟動環境時,將會看到與如下內容類似的訊息。
# luactivate c1t2d0s0 WARNING: The following files have changed on both the current boot environment <ZFSbe> zone <global> and the boot environment to be activated <c1t2d0s0>: /etc/zfs/zpool.cache INFORMATION: The files listed above are in conflict between the current boot environment <ZFSbe> zone <global> and the boot environment to be activated <c1t2d0s0>. These files will not be automatically synchronized from the current boot environment <ZFSbe> when boot environment <c1t2d0s0> |