Sun Cluster 系統管理指南 (適用於 Solaris 作業系統)

如何復原元式裝置上的根 (/) 檔案系統 (Solstice DiskSuite/Solaris Volume Manager)

使用此程序復原執行備份時元式裝置上的根 (/) 檔案系統。 在根磁碟毀損而換成新磁碟等情況下執行這個程序。 要復原的節點應該不在啟動狀態。 請先確定叢集執行時沒有任何錯誤,再執行復原程序。


註解 –

由於您必須將新磁碟分割成和故障磁碟相同的格式,請在進行本程序之前先識別分割區機制,同時適當地重新建立檔案系統。


  1. 在可存取 metaset 的叢集節點上,而不是您要復原的節點上,成為超級使用者。

  2. 從所有 metaset 中移除已復原的節點主機名稱。


    # metaset -s setname -f -d -h nodelist
    

    -s setname

    指定 metaset 名稱。

    -f

    強迫。

    -d

    從 metaset 刪除。

    -h nodelist

    指定要從 metaset 刪除之節點的名稱。

  3. 置換節點上要復原 root (/) 檔案系統的故障磁碟。

    請參閱隨附伺服器之說明文件中敘述的磁碟置換程序。

  4. 啟動您要復原的節點。

    • 如果您使用的是 Solaris CD︰

      • SPARC︰出現 OpenBoot PROM ok 提示符號時,請鍵入以下指令︰


         ok boot cdrom -s
        

      • x86︰將 CD 插入 系統的 CD 磁碟機,並透過關閉系統、然後關閉電源再開啟電源的方法來啟動系統。 在 [目前的啟動參數] 畫面上,鍵入以下指令︰


                             <<< Current Boot Parameters >>>
        Boot path: /pci@0,0/pci8086,2545@3/pci8086,1460@1d/pci8086,341a@
        7,1/sd@0,0:a
        Boot args:
        
        Type b [file-name] [boot-flags] <ENTER> to boot with options
        or   i <ENTER>                          to enter boot interpreter
        or   <ENTER>                            to boot with defaults
        
                         <<< timeout in 5 seconds >>>
        Select (b)oot or (i)nterpreter: b -s
        

    • 如果您使用的是 Solaris JumpStartTM 伺服器︰

      • SPARC︰出現 OpenBoot PROM ok 提示符號時,請鍵入以下指令︰


        ok boot net -s
        

      • x86︰使用關閉系統、然後關閉電源再開啟電源的方法來啟動系統。 在 [目前的啟動參數] 畫面上,鍵入以下指令︰


                             <<< Current Boot Parameters >>>
        Boot path: /pci@0,0/pci8086,2545@3/pci8086,1460@1d/pci8086,341a@
        7,1/sd@0,0:a
        Boot args:
        
        Type b [file-name] [boot-flags] <ENTER> to boot with options
        or   i <ENTER>                          to enter boot interpreter
        or   <ENTER>                            to boot with defaults
        
                         <<< timeout in 5 seconds >>>
        Select (b)oot or (i)nterpreter: b -s
        

  5. 使用 format 指令,在根磁碟上建立所有的分割區與交換。

    重新建立故障磁碟的原始分割機制。

  6. 使用 newfs 指令,適當建立根 (/) 檔案系統以及其他檔案系統

    重新建立故障磁碟的原始檔案系統。


    註解 –

    請務必要建立 /global/.devices/node@nodeid 檔案系統。


  7. 將 root (/) 檔案系統裝載到暫時裝載點。


    # mount device temp-mountpoint
    

  8. 使用下列指令來復原 root (/) 檔案系統。


    # cd temp-mountpoint
    # ufsrestore rvf dump-device
    # rm restoresymtable
    

  9. 在新磁碟上安裝新的啟動區塊。


    # /usr/sbin/installboot /usr/platform/`uname -i`/lib/fs/ufs/bootblk raw-disk-device
    

  10. 移除在 /temp-mountpoint/etc/system 檔中 MDD 根資訊的行。


    * Begin MDD root info (do not edit)
    forceload: misc/md_trans
    forceload: misc/md_raid
    forceload: misc/md_mirror
    forceload: misc/md_hotspares
    forceload: misc/md_stripe
    forceload: drv/pcipsy
    forceload: drv/glm
    forceload: drv/sd
    rootdev:/pseudo/md@0:0,10,blk
    * End MDD root info (do not edit)

  11. 編輯 /temp-mount-point/etc/vfstab 檔,將在複合裝置部分的根磁碟上,用來作為每個檔案系統的根登錄從複合裝置變更為對應的一般片段。


    Example: 
    Change from—
    /dev/md/dsk/d10   /dev/md/rdsk/d10    /      ufs   1     no       -
    
    Change to—
    /dev/dsk/c0t0d0s0 /dev/rdsk/c0t0d0s0  /      ufs   1     no       -

  12. 卸載暫存檔案系統,然後檢查原始磁碟裝置。


    # cd /
    # umount temp-mountpoint
    # fsck raw-disk-device
    

  13. 將節點重新啟動為單使用者模式。


    # reboot -- "-s"
    

  14. 使用 scdidadm 指令置換磁碟 ID。


    # scdidadm -R rootdisk
    

  15. 使用 metadb 指令重新建立狀態資料庫副本。


    # metadb -c copies -af raw-disk-device
    

    -c copies

    指定要建立的複本數目。

    -af raw-disk-device

    在指名的原始磁碟裝置上建立初始狀態資料庫複本。

  16. 將節點重新啟動為叢集模式。

    1. 重新啟動。


      # reboot
      

      啟動期間將會看到錯誤或警告訊息,結尾部分附有以下指示:


      Type control-d to proceed with normal startup,
      (or give root password for system maintenance):

    2. 按下 Ctrl-d 啟動為多重使用者模式。

  17. 在已復原節點以外的叢集節點上,使用 metaset 指令將復原的節點新增到所有 metaset。


    phys-schost-2# metaset -s setname -a -h nodelist
    

    -a

    新增 (建立) metaset。

    依照 Solstice DiskSuite 說明文件,設定 root (/) 的 metadevice/mirror。

    節點重新啟動為叢集模式。 叢集已經備妥可以使用。

範例—復原複合裝置 (Solstice DiskSuite/Solaris Volume Manager) 上舊的 root (/) 檔案系統

以下範例顯示 root (/) 檔案系統復原至節點 phys-schost-1 (從磁帶裝置 /dev/rmt/0)。 metaset 指令是從叢集的其他節點 phys-schost-2 執行,以便先移除而後將節點 phys-schost-1 重新加入 metaset schost-1 中。 所有其他指令是由 phys-schost-1 執行。 在 /dev/rdsk/c0t0d0s0 上將建立新的啟動區段,並在 /dev/rdsk/c0t0d0s4 上重新建立三個狀態資料庫副本。


[Become superuser on a cluster node with access to the metaset, 
other than the node to be restored.]
[Remove the node from the metaset:]
phys-schost-2# metaset -s schost-1 -f -d -h phys-schost-1
[Replace the failed disk and boot the node:]

從 Solaris CD 啟動節點︰


[Use format and newfs to recreate partitions and file systems.]
[Mount the root file system on a temporary mount point:]
# mount /dev/dsk/c0t0d0s0 /a
[Restore the root file system:]
# cd /a
# ufsrestore rvf /dev/rmt/0
# rm restoresymtable
[Install a new boot block:]
# /usr/sbin/installboot /usr/platform/`uname \
-i`/lib/fs/ufs/bootblk /dev/rdsk/c0t0d0s0
[Remove the lines in /temp-mountpoint/etc/system file for MDD root information:]
* Begin MDD root info (do not edit)
forceload: misc/md_trans
forceload: misc/md_raid
forceload: misc/md_mirror
forceload: misc/md_hotspares
forceload: misc/md_stripe
forceload: drv/pcipsy
forceload: drv/glm
forceload: drv/sd
rootdev:/pseudo/md@0:0,10,blk
* End MDD root info (do not edit)
[Edit the /temp-mountpoint/etc/vfstabfile]
Example: 
Change from—
/dev/md/dsk/d10   /dev/md/rdsk/d10    /      ufs   1     no       -

Change to—
/dev/dsk/c0t0d0s0 /dev/rdsk/c0t0d0s0  /usr   ufs   1     no       -
[Unmount the temporary file system and check the raw disk device:]
# cd /
# umount /a
# fsck /dev/rdsk/c0t0d0s0
[Reboot in single-user mode:]
# reboot -- "-s"
[Replace the disk ID:]
# scdidadm -R /dev/dsk/c0t0d0
[Recreate state database replicas:]
# metadb -c 3 -af /dev/rdsk/c0t0d0s4
# reboot
Type Control-d to boot into multiuser mode.
[Add the node back to the metaset:]
phys-schost-2# metaset -s schost-1 -a -h phys-schost-1