ghettoVCB-restore.sh 介紹
ghettoVCB-restore.sh 主要是用來還原備份,也屬於ghettoVCB中的一部份。
在這個腳本中支持兩個主要的用途
使用腳本時先注意,該還原目地有足夠的空間,然後在嘗試還原。以避免問題的產生。
支持的還原格式: zeroedthick(default behavior)、2gbsparse、thin、eagerzeroedthick。
使用需求
上一篇 (VMesxi 備份篇-Day22) VMware ESXi 備份 ghettoVCB.sh 進階設定
下一篇 (VMesxi 備份篇-Day24) VMware ESXi ghettoVCB 版本問題和錯誤訊息
VMware vSphere Hypervisor (ESXi) 30天基礎速成班(文章彙整)
文章同步 FAQ BOOK
前置作業
相信會使用到還原的部份,想必都已經下載好相關檔案才對。所以在此部份就簡單帶過,若有不懂的可參考 [(VMesxi 備份篇-Day21) VMware ESXi 備份 ghettoVCB.sh 基本設定]前半段設定。
1. 開啟 SSH
2. 下載 ghettoVCB
官方載點 : Download as zip 、 Download as tar.gz
本站載點 : Download as zip 、 Download as tar.gz
在下載 ghettoVCB 檔案的部份會有兩個選項 [Download as zip] 和 [Download as tar.gz]。兩個檔案內容都一樣。所以可自行選擇要那一種方式。
在這邊選擇 [Download as tar.gz]的方式下載
3. 上傳 ghettoVCB
ghettoVCB-restore.sh 設定
注意事項
因5.1版為最新版本,而 ghettoVCB 尚未更新至最新板。如果是使用VMware ESXi 5.1版的,在 ghettoVCB-restore.sh 以下有個地方要修改。要不然在使用上會出現版本序號有問題。
大約在第87行會看到以下程式碼,請加入 || [[ "${ESX_VERSION}" == "5.1.0" ]]。多加上5.1版本的判斷。
這邊有修改好的 ghettoVCB-restore.sh
~ # vi ghettoVCB-restore.sh
# 修改前
86 ESX_VERSION=$(vmware -v | awk '{print $3}')
87 if [ "${ESX_VERSION}" == "5.0.0" ]; then
88 VER=5
# 修改後
86 ESX_VERSION=$(vmware -v | awk '{print $3}')
87 if [ "${ESX_VERSION}" == "5.0.0" ] || [[ "${ESX_VERSION}" == "5.1.0" ]]; then
88 VER=5
修改前
修改後
1. 解壓縮上傳的資料
解壓縮後會看到ghettoVCB-restore.sh。此檔案就是用來設定備份還原。
~ # tar -zxvf lamw-ghettoVCB-518cef7.tar.gz
tar: warning: skipping header 'g'
lamw-ghettoVCB-518cef7/
lamw-ghettoVCB-518cef7/README
lamw-ghettoVCB-518cef7/ghettoVCB-restore.sh
lamw-ghettoVCB-518cef7/ghettoVCB-restore_vm_restore_configuration_template
lamw-ghettoVCB-518cef7/ghettoVCB-vm_backup_configuration_template
lamw-ghettoVCB-518cef7/ghettoVCB.conf
lamw-ghettoVCB-518cef7/ghettoVCB.sh
~ # cd lamw-ghettoVCB-518cef7
~ # ls ghettoVCB-vm_backup_configuration_template README
ghettoVCB-restore.sh ghettoVCB.conf
ghettoVCB-restore_vm_restore_configuration_template ghettoVCB.sh
2. ghettoVCB-restore.sh參數使用說明
以下是ghettoVCB-restore.s相關參數的使用說明
~ # ./ghettoVCB-restore.sh
###############################################################################
#
# ghettoVCB-restore for ESX/ESXi 3.5, 4.x+ and 5.0
# Author: William Lam
# http://www.virtuallyghetto.com/
# Documentation: http://communities.vmware.com/docs/DOC-8760
# Created: 08/18/2009
# Last modified: 2011_11_19_1
#
###############################################################################
Usage: ./ghettoVCB-restore.sh -c [VM_BACKUP_UP_LIST] -l [LOG_FILE] -d [DRYRUN_DEBUG_INFO]
OPTIONS:
-c VM backup list (依造list中的設定還原備份)
-l File ot output logging (指定LOG所要儲存的路徑)
-d Dryrun/Debug Info [1|2] (可用來測試或是Debug還原看是否有誤)
(e.g.)
Output will go to stdout
針對list表中的VM虛擬機還原
./ghettoVCB-restore.sh -c vms_to_restore
Output will log to /tmp/ghettoVCB-restore.log
設定在虛擬機還原後的記錄LOG存放位置
./ghettoVCB-restore.sh -c vms_to_restore -l /tmp/ghettoVCB-restore.log
Dryrun/Debug Info (dryrun only)
可針對要還原的虛擬機做Dryrun/Debug
./ghettoVCB-restore.sh -c vms_to_restore -d 1
./ghettoVCB-restore.sh -c vms_to_restore -d 2
3. 還原設定開始
3.1 建立還原使用的list
建立list主要是為了在還原的時後較為方便。然而在這一份list中有幾點要注意的。
(1) VM備份檔所在地的完整路徑。
(2) 恢復後的VM要存放的完整路徑
(3) 設定還原後硬碟的格式 (格式不懂的可以參考(VMesxi 備份篇-Day19) VMware vSphere(ESXi) 虛擬硬碟格式介紹)
格式代號 格式名稱
1 = zeroedthick (固定大小 不會初始化)
2 = 2gbsparse (特殊格式分割為數個2G的檔案)
3 = thin (動態大小)
4 = eagerzeroedthick (固定大小 會初始化)
(4) 此list請使用在ESX或ESXi主機上。請勿用在non-Linux/UNIX系統上,避免特殊符號影響導致腳本錯誤。
List 腳本格式
"/vmfs/volumes/datastore1/backup/VM1/VM1-2012-10-18_23-48-35;/vmfs/volumes/datastore1;4"
"[VM備份檔所在地的完整路徑];[ 還原後的VM要存放的完整路徑];[ 還原硬碟的格式]"
[VM備份檔所在地的完整路徑] : /vmfs/volumes/datastore1/backup/VM1/VM1-2012-10-18_23-48-35
[還原後的VM要存放的完整路徑] : /vmfs/volumes/datastore1
[還原硬碟的格式] :
DISK_FORMATS
1 = zeroedthick
2 = 2gbsparse
3 = thin
4 = eagerzeroedthick
在這邊要注意一下是「;」而不是「:」
List設定範例
在list設定裡可以直接把硬碟的格式代號也加入,方便日後查詢。不過要記得 # 才不會影響到腳本。
~ # vi vms_to_restore
# DISK_FORMATS
# 1 = zeroedthick
# 2 = 2gbsparse
# 3 = thin
# 4 = eagerzeroedthick
# e.g.
"/vmfs/volumes/datastore1/backup/VM1/VM1-2012-10-18_23-48-35;/vmfs/volumes/datastore1;4"
# 在這邊要注意一下是「;」而不是「:」
3.2 測試Dryrun/Debug
設定好vms_to_restore後,可以使用Dryrun/Debug來測試看看腳本和vms_to_restore是否有問題。若是有問題,過程中會報錯。
Dryrun/Debug Info [1|2]
Dryrun:
~ # ./ghettoVCB-restore.sh -c vms_to_restore -d 1
Debug:
~ # ./ghettoVCB-restore.sh -c vms_to_restore -d 2
3.3 還原備份
要還原備份時請使用參數「-c」然後接 vms_to_restore 也就是剛剛所設定的list
參數說明
~ # ./ghettoVCB-restore.sh -c vms_to_restore
-c : 依照List中的設定還原備份
vms_to_restore : 設定list
開始還原
~ # ./ghettoVCB-restore.sh -c vms_to_restore
################## Restoring VM: test #####################
Start time: Wed Jan 11 23:52:11 UTC 2012
Restoring VM from: "/vmfs/volumes/datastore1/backup/backup/test/test-2012-10-18_23-48-35"
Restoring VM to Datastore: "/vmfs/volumes/datastore1" using Disk Format: "eagerzeroedthick"
Creating VM directory: "/vmfs/volumes/datastore1/test-2012-10-18_23-48-35" ...
Copying "test.vmx" file ...
Restoring VM's VMDK(s) ...
Updating VMDK entry in "test.vmx" file ...
Destination disk format: VMFS eagerzeroedthick
Cloning disk '/vmfs/volumes/datastore1/backup/backup/test/test-2012-10-18_23-48-35/test.vmdk'...
Clone: 100% done.
Registering test ...
23
End time: Wed Jan 11 23:52:29 UTC 2012
################## Completed restore for test! #####################
Start time: Wed Jan 11 23:52:11 UTC 2012
End time: Wed Jan 11 23:52:29 UTC 2012
Duration : 18 Seconds
查看還原
還原完成後開啟VMware vSphere Client會看到剛剛所還原回去的VM已經掛上了。
接下來就可以開啟VM後測試看試否有問題。
4 備份log設定
如果要設定log的話,會建議把log存在不會因重開機,而刪檔的地方。
若只是要測試的話就放在/tmp下就可以了。
參數說明
~ # ./ghettoVCB-restore.sh -c vms_to_restore -l /vmfs/volumes/datastore1/log/ghettoVCB-restore.log
~ # ./[ghettoVCB-restore.sh] -c [list] -l [Log存放路徑]
還原備份並設定LOG存放處
~ # ./ghettoVCB-restore.sh -c vms_to_restore -l /vmfs/volumes/datastore1/log/ghettoVCB-restore.log
Logging output to "/tmp/ghettoVCB-restore.log" ...
Destination disk format: VMFS eagerzeroedthick
Cloning disk '/vmfs/volumes/datastore1/backup/backup/test/test-2012-10-18_23-48-35/test.vmdk'...
Clone: 100% done.
#備份完成,到LOG存放地方查看log
~ # cat/vmfs/volumes/datastore1/log/ghettoVCB-restore.log
Destination disk format: VMFS eagerzeroedthick
Cloning disk '/vmfs/volumes/datastore1/backup/backup/test/test-2012-10-18_23-48-35/test.vmdk'...
Clone: 100% done.
Registering test ...
End time: Thu Jan 12 00:05:47 UTC 2012
################## Completed restore for test! #####################
Start time: Thu Jan 12 00:05:30 UTC 2012
End time: Thu Jan 12 00:05:47 UTC 2012
Duration : 17 Seconds
到這邊備份還原的部份就ok了,剩下運用的部份就由個人自行發揮。
上一篇 (VMesxi 備份篇-Day22) VMware ESXi 備份 ghettoVCB.sh 進階設定
下一篇 (VMesxi 備份篇-Day24) VMware ESXi ghettoVCB 版本問題和錯誤訊息
VMware vSphere Hypervisor (ESXi) 30天基礎速成班(文章彙整)