新四季網

遷移虛擬機的方法和裝置的製作方法

2023-07-16 13:09:01

專利名稱:遷移虛擬機的方法和裝置的製作方法
技術領域:
本發明涉及虛擬機的遷移,更具體而言,涉及將虛擬機進行跨站點遷移的方法和
>J-U裝直。
背景技術:
為了提高數據存儲的安全性和持續性,越來越多的企業選擇建立跨站點(crosssite)的數據中心,由此防止災害發生或者進行負載的調整和平衡。另一方面,隨著虛擬化技術的發展,許多數據中心採用虛擬機來執行並管理。在進行站點維護、功率調整、平衡站 點之間的負載等多種情況下,都需要對站點中承載的虛擬機進行遷移,也就是將虛擬機從一個物理系統遷移到一個不同的物理系統。然而,如何使得虛擬機進行遷移而不影響其上的應用和服務成為值得研究的問題。多數提供主機虛擬化的公司都具有其特定的虛擬機遷移工具。例如,PowerVM提供了一種虛擬機遷移功能,能夠將運行中的虛擬機移動到不同的物理系統,而不產生當機時間。VMware具有類似的虛擬機遷移工具,稱為VMotion。然而,以上兩種遷移工具都要求遷移前後的物理機之間米用 SAN(storage area network),NAS(network-attached storage)之類的集中式共享外存設備。這樣的要求將虛擬機的遷移局限在同一站點之內,而無法實施跨站點的遷移。進一步地,為了克服上述局限性,一些專利還提出了其他的解決方案來進行跨站點的虛擬機遷移。在一個方案中提出,可以將虛擬機掛起並鏡像成為一個映像,然後通過網絡複製該映像,最後在另一計算機系統中重新啟動該映像,從而實現虛擬機的遷移。然而,上述過程是一個先停止再複製的過程,會明顯地中斷虛擬機的運行,造成虛擬機上的應用或服務中斷或超時。在另一種方案中提出,在主機之間動態建立光通路,從而通過光網絡來將一個虛擬機從源站點遷移到目標站點。但是,該方案需要在每個虛擬機上安裝可調的控制代理,並要求在主機之間具有S0NET/SDH或DWDM連接來複製內存和磁碟中的數據。可以理解,在虛擬機遷移的同時,希望各個應用和服務仍在運行,因此磁碟上仍然存在數據的讀寫和改變。當磁碟的數據改變速率高於網絡複製速率時,就會有一部分數據無法被複製到目標站點,從而造成數據丟失。因此,該方案無法解決數據的一致性問題,這對於虛擬機遷移的安全性非常不利。

發明內容
考慮到上述問題,指出本發明,旨在提供一種跨站點的虛擬機遷移方案。根據本發明第一方面,提供一種切換管理設備,用於在虛擬機的異步遷移中基於虛擬機內存數據的遷移協助進行虛擬機存儲數據的切換,其中所述存儲數據的切換是將存儲數據從第一站點中的第一存儲設備切換到第二站點中的第二存儲設備,其中第一存儲設備和第二存儲設備之間建立有同步鏡像關係,所述設備包括通信單元,配置為在按照路徑表訪問第一存儲設備失敗時,發出訪問失敗報告;鏡像修改單兀,配置為響應於所述失敗報告,修改第一存儲設備和第二存儲設備之間的鏡像方向;通知單元,配置為發出路徑修改通知,要求更改到第二存儲設備的路徑設置;路徑修改單元,配置為根據所述路徑修改通知,通過修改路徑表來激活到第二存儲設備的路徑,使得第二存儲設備能夠被訪問。根據本發明第二方面,提供一種硬體管理裝置,用於在虛擬機的異步遷移中協助進行虛擬機內存數據的遷移以作為虛擬機存儲數據切換的基礎,其中所述內存數據的遷移是將內存數據從第一站點中的第一主機遷移到第二站點中的第二主機,其中第一站點還包括第一存儲設備,第二站點還包括第二存儲設備,所述第一存儲設備和第二存儲設備之間建立有同步鏡像關係,所述裝置包括接收單元,配置為接收遷移指令和第二站點的信息;複製單元,配置為指示第一主機將虛擬機的內存數據複製到所述第一存儲設備中的子邏輯單元,所述子邏輯單元在所述第二存儲設備中存在鏡像邏輯單元;通知單元,配置為根據所述第二站點的信息發出通知,所述通知用於指示第二主機從所述鏡像邏輯單元讀取內存數據。在本發明的其他方面還提供了與上述方面對應的方法。
根據本發明的裝置和方法,利用同步鏡像方式實現虛擬機數據的遷移和切換,從而實時地在不同站點之間遷移虛擬機,而不影響虛擬機及其應用的運行。


圖I示出根據本發明一個實施例的系統的架構圖;圖2示出根據本發明一個實施例的硬體管理裝置的示意框圖;圖3示出根據本發明一個實施例的內存複製示意圖;圖4示出根據本發明一個實施例的鏡像管理裝置的示意框圖;圖5示出根據本發明一個實施例的路徑管理裝置的示意框圖;圖6示出在一個具體例子中鏡像管理裝置和路徑管理裝置的交互示意圖;圖7示出根據本發明一個實施例的切換管理設備的示意圖;圖8示出根據本發明一個實施例的遷移內存數據的方法的流程圖;以及圖9示出根據本發明一個實施例的切換存儲數據的方法的流程圖。圖10示出了適於用來實現本發明實施方式的示例性計算系統1000的框圖。
具體實施例方式所屬技術領域的技術人員知道,本發明的多個方面可以體現為系統、方法或電腦程式產品。因此,本發明的多個方面可以具體實現為以下形式,即,可以是完全的硬體、完全的軟體(包括固件、駐留軟體、微代碼等)、或者本文一般稱為「電路」、「模塊」或「系統」的軟體部分與硬體部分的組合。此外,本發明的多個方面還可以採取體現在一個或多個計算機可讀介質中的電腦程式產品的形式,該計算機可讀介質中包含計算機可用的程序碼。可以使用一個或多個計算機可讀的介質的任何組合。計算機可讀介質可以是計算機可讀信號介質或者計算機可讀存儲介質。計算機可讀存儲介質例如可以是一但不限於——電的、磁的、光的、電磁的、紅外線的、或半導體的系統、裝置、器件或任何以上的組合。計算機可讀存儲介質的更具體的例子(非窮舉的列表)包括以下有一個或多個導線的電連接、可攜式計算機磁碟、硬碟、隨機存取存儲器(RAM)、只讀存儲器(ROM)、可擦式可編程只讀存儲器(EPROM或快閃記憶體)、光纖、可攜式緊湊磁碟只讀存儲器(CD-ROM)、光存儲器件、磁存儲器件、或者上述的任何合適的組合。在本文件的語境中,計算機可讀存儲介質可以是任何包含或存儲程序的有形的介質,該程序被指令執行系統、裝置或者器件使用或者與其結合使用。計算機可讀的信號介質可包括在基帶中或者作為載波一部分傳播的、其中體現計算機可讀的程序碼的傳播的數據信號。這種傳播的信號可以採用多種形式,包括——但不限於——電磁信號、光信號或任何以上合適的組合。計算機可讀的信號介質可以是並非為計算機可讀存儲介質、但是能發送、傳播或者傳輸用於由指令執行系統、裝置或者器件使用或者與其結合使用的程序的任何計算機可讀介質。計算機可讀介質上包含的程序代碼可以用任何適當的介質傳輸,包括——但不限於——無線、電線、光纜、RF等等,或者任何合適的上述組合。計算機可讀介質上包含的程序代碼可以用任何適當的介質傳輸,包括一但不限於——無線、電線、光纜、RF等等,或者任何合適的上述組合。
用於執行本發明的操作的電腦程式碼,可以以一種或多種程序設計語言的任何組合來編寫,所述程序設計語言包括面向對象的程序設計語言-諸如Java、Smalltalk、C++之類,還包括常規的過程式程序設計語言-諸如」C」程序設計語言或類似的程序設計語言。程序碼可以完全地在用戶的計算上執行、部分地在用戶的計算機上執行、作為一個獨立的軟體包執行、部分在用戶的計算機上部分在遠程計算機上執行、或者完全在遠程計算機或伺服器上執行。在後一種情形中,遠程計算機可以通過任何種類的網絡一包括區域網(LAN)或廣域網(WAN)-連接到用戶的計算機,或者,可以(例如利用網際網路服務提供商來通過網際網路)連接到外部計算機。以下參照按照本發明實施例的方法、裝置(系統)和電腦程式產品的流程圖和/或框圖描述本發明的多個方面。要明白的是,流程圖和/或框圖的每個方框以及流程圖和/或框圖中各方框的組合,都可以由電腦程式指令實現。這些電腦程式指令可以提供給通用計算機、專用計算機或其它可編程數據處理裝置的處理器,從而生產出一種機器,使得通過計算機或其它可編程數據處理裝置執行的這些指令,產生實現流程圖和/或框圖中的方框中規定的功能/操作的裝置。也可以把這些電腦程式指令存儲在能指令計算機或其它可編程數據處理裝置以特定方式工作的計算機可讀介質中,這樣,存儲在計算機可讀介質中的指令產生一個包括實現流程圖和/或框圖中的方框中規定的功能/操作的指令裝置(instruction means)的製造品。也可以把電腦程式指令加載到計算機或其它可編程數據處理裝置上,使得在計算機或其它可編程數據處理裝置上執行一系列操作步驟,以產生計算機實現的過程,從而在計算機或其它可編程裝置上執行的指令就提供實現流程圖和/或框圖中的方框中規定的功能/操作的過程。下面參照附圖,結合具體實施例對本發明進行描述。這樣的描述僅僅出於說明目的,而不意圖對本發明的範圍進行限制。在本發明的多個實施例中,通過數據的同步鏡像(Metro Mirror)和切換(swap),實現虛擬機的實時(live)跨站點遷移。一般來說,虛擬機的遷移主要包括作業系統的遷移和存儲數據的遷移,同時照顧主機級別的差異並處理不同的虛擬硬體。上述作業系統的遷移包括將與虛擬機的運行相關的重要數據進行複製或移動。只有將這些數據從源站點遷移到目標站點,才能使得虛擬機在目標站點的主機中啟動。這樣的數據例如包括,作業系統中的進程、系統狀態、系統上運行的應用的狀態等,這些數據一般存儲在主機的內存之中。因此,通常也將作業系統的遷移稱為內存的遷移或主機的遷移。另一方面,存儲數據的遷移主要包括將存儲在大容量非易失性存儲設備(例如磁碟)中的數據從源站點遷移到目標站點。通常,這樣的遷移也稱為存儲設備的遷移。對於實時遷移來說,希望運行在源站點中的虛擬機能夠在極短的時間內遷移到目標站點並啟動,也就是說,要將內存中的數據和存儲設備中的數據都複製到目標站點,並儘可能不影響虛擬機的運行。為了滿足這樣的遷移速度的要求,可以採用同步鏡像方式預先在源站點的存儲設備和目標站點的存儲設備之間建立鏡像關係,從而實現數據的複製和備份。在同步鏡像的方案中,來自主機的數據被寫往本地連接的磁碟系統,該磁碟系統同時將數據轉發給遠程連接的磁碟系統。只有當兩個磁碟系統都擁有數據的拷貝以後,本地系統才會向主機返回一個I/o完成指示。由此,在同步鏡像方案下,本地存儲設備和遠程的備用存儲設備都會保持最新的更新。通常來說,具有同步鏡像關係的磁碟系統之間通過光纖網絡進行數據傳輸,從而實現高速數據複製。在一種執行方式下,通過鏡像管理裝置來管理存儲設備的鏡像關係。為了利用同步鏡像方式完成虛擬機的遷移,在本發明的實施例中,可以提供改進的硬體管理裝置來進行內存數據的複製和遷移。在此基礎上,本發明實施例還提供鏡像管理裝置和路徑管理裝置,這些裝置互相通信,彼此協作,從而協助進行虛擬機的存儲數據的切換。相對於將整個虛擬機作為一個映像進行傳輸的方案來說,分別進行內存數據的遷移和存儲數據的切換的虛擬機遷移方案可以稱為虛擬機的異步遷移。
圖I示出根據本發明一個實施例的系統的架構圖。如圖所示,虛擬機最初運行在源站點1000,或稱第一站點的主機之中,並向源站點中本地連接的存儲設備(或稱源存儲設備或第一存儲設備)讀寫數據。相應地,在第二站點2000,或稱目標站點中提供了對應的主機和存儲設備,分別稱為第二主機和第二存儲設備。為了將虛擬機從第一站點遷移到第二站點,在第一存儲設備和第二存儲設備之間建立同步鏡像關係。獨立於第一主機和第二主機,提供鏡像管理裝置20,通過管理數據的鏡像和切換,協助進行虛擬機的遷移。並且,與站點內的主機相對應地提供硬體管理裝置10,通過管理內存數據的複製來協助進行虛擬機的遷移。因此,第一主機和第二主機各自具有對應的硬體管理裝置10,它們之間可以互相通信。每個硬體管理裝置可以直接指示對應的主機執行特定的操作。進一步地,在主機上所運行的虛擬機中安裝路徑管理裝置30,通過管理存儲設備的訪問路徑來協助進行虛擬機的遷移。以下具體描述各個裝置的工作方式。硬體管理裝置10與主機相對應,用以管理該主機中包括內存在內的硬體系統,協助實現內存的複製。在一個實施例中,硬體管理裝置可以通過在現有技術的硬體管理控制臺(Hardware Manage Console, HMC)的基礎上擴展功能而實現。在一個實施例中,硬體管理裝置10配置為利用光纖網絡實現內存數據的複製。儘管相比於磁碟數據來說內存數據並不算太大,但是如果通過常規乙太網進行傳輸,仍然會造成較大的網絡負擔,並且難以保證實時遷移所要求的短時間內的快速複製。因此,硬體管理裝置10可以利用乙太網進行常規的信號通信,而利用光纖網絡進行內存數據的複製。圖2示出根據本發明一個實施例的硬體管理裝置的示意框圖。如圖所示,硬體管理裝置10包括接收單元12,復 制單元14和通知單元16。具體地,在一個例子中,接收單元12可以作用為接口,配置為接收遷移指令和第二站點的信息。由此,用戶可以在需要遷移虛擬機時,通過接收單元12發出遷移指令,並指明遷移的目標站點的信息。例如,用戶可以指定目標主機的IP位址或其他標識信息,使得硬體管理裝置10能夠確定遷移的目的地。接著,硬體管理裝置10根據獲得的第二站點的信息,通過常規方式與第二主機所對應的硬體管理裝置,進而與第二主機進行信號通信,為數據的複製進行網絡方面的準備。之後,複製單元14根據第二站點的信息,指示第一主機通過光纖網絡將內存中的數據直接複製到第二站點,更具體地,複製到第二站點中的第二主機中。在複製完成後,通知單元16通過第二主機對應的硬體管理裝置向第二主機發出通知,通知其讀取內存數據,從而啟動虛擬機的作業系統。在另一實施例中,硬體管理裝置10利用已經建立的同步鏡像關係來進行內存的複製。圖3示出根據本發明一個實施例的內存複製示意圖。在圖中,第一站點中的第一存儲設備已經與第二站點中的第二存儲設備建立了同步鏡像關係。如本領域人員所知,每個存儲設備包括多個邏輯單元,通常用LUN(logical unit number)來指代。存儲設備之間的同步鏡像關係實際上是由各個邏輯單元LUN之間的同步鏡像關係構成的。根據圖3的複製方案,在第一站點的第一存儲設備中設立一塊小容量的子邏輯單元,如LUNls所示,其大小與虛擬機的內存大小相當。在此基礎上,硬體管理裝置10中的複製單元14配置為,響應於遷移指令,指示第一主機將虛擬機的內存信息複製到該子邏輯單元LUNls。由於第一存儲設備和第二存儲設備之間已經建立了同步鏡像關係,因此內存數據在複製到LUNls的同時,會通過光纖網絡寫入第二存儲設備中與LUNls相對應的鏡像單元LUN2s。於是,在LUN2s中就存在了仍然在第一主機中運行的虛擬機的內存數據。在完成內存複製之後,通知單元16根據上述的第二站點的信息,向第二主機對應的硬體管理裝置發出通知,第二主機對應的硬體管理裝置於是向第二主機發出指示,指示其從第二存儲設備讀取鏡像單元LUN2s中的數據。由此,第二主機就能夠從本地連接的第二存儲設備中讀取LUN2s中的數據作為內存數據,並基於這些內存數據啟動虛擬機。在以上配置方案中,複製單元14首先指示第一主機將內存數據複製到第一存儲設備;由於第一主機和第一存儲設備是本地連接的,因此這個複製過程非常快速。進一步地,基於第一存儲設備和第二存儲設備之間的同步鏡像關係,數據同時被寫入第二存儲設備。由於同步鏡像關係是預先設立完成的,因此這個寫入過程復用了已經構建好的同步鏡像光纖網絡,速度快且效率高。接著,通知單元16通過第二主機對應的硬體管理裝置向第二主機發出讀取數據的通知。如上所述,這樣的通知信號可以通過乙太網來傳輸。在接收到通知信號之後,第二主機就可以從第二存儲設備中讀取數據了。同樣地,由於第二主機和第二存儲設備是本地連接的,因此這個讀取過程也非常迅速。因此,在這個配置方案中,儘管內存數據不是直接複製到第二主機而是藉由存儲設備之間的鏡像來完成,但是,由於每個數據傳遞過程都非常快速,並且利用了已經構建的光纖網絡,因此複製效率也很高。在一個實施例中,複製單元14指示主機分步驟地進行內存的複製。例如,複製單元14首先指示主機複製內存數據中的核心數據,也就是,啟動虛擬機的作業系統所必須的最重要的數據;然後,複製其餘的補充數據,例如狀態數據。現有技術中已經存在多種算法和方案來判定和區分核心數據。複製單元14可以利用這樣的現有技術在內存數據中選擇出核心數據,並優先對核心數據進行複製。由此,作業系統相關數據可以在儘量短的時間內得到遷移,因此虛擬機可以儘快地在目標主機中開始啟動,從而縮短停機時間。通過上述實施例的硬體管理裝置10,虛擬機的內存數據從第一主機複製到了第二主機。於是,虛擬機的作業系統會在第二主機中重新啟動。然而,此時,當虛擬機試圖訪問相關聯的存儲設備時,就會出現訪問失敗的情況。這是因為,虛擬機的內存數據只是複製到了第二主機中,作業系統中的相關配置並未發生改變。因此,在第二主機上重新啟動的虛擬機會按照原有配置運行作業系統。可以理解,按照原有配置,第一存儲設備是本地連接的存儲設備,作業系統可以直接訪問其中的LUN。因此,在作業系統已經遷移到第二主機的情況下,虛擬機仍然會將第一存儲設備作為默認的本地存儲設備,利用原有路徑試圖進行訪問。然而,由於第二主機和第一存儲設備並不位於同一站點,顯然,這樣的訪問不會獲得成功。這時,就需要更改相關配置信息,切換存儲設備,才能使得虛擬機正常工作。
為了將存儲設備從第一站點切換到第二站點,在本發明一個實施例中,對圖I中的鏡像管理裝置20和路徑管理裝置30進行配置,使其互相協作,共同完成存儲設備的切換。具體地,在一個實施例中,鏡像管理裝置20通過在現有的鏡像管理裝置,例如IBM的TPC_R(Total Productivity Center for Replication)的基礎上進行功能擴展而實現。或者,鏡像管理裝置20也可以完全獨立於現有鏡像管理裝置而實現。作為鏡像管理的基本功能,裝置20維持並保存有第一存儲設備和第二存儲設備之間的鏡像關係。為了協助進行存儲數據的切換,鏡像管理裝置20進ー步配置為圖4所示的結構。圖4示出根據本發明一個實施例的鏡像管理裝置的示意框圖。如圖所示,鏡像管理裝置20包括鏡像修改単元22,配置為響應於接收到的第一存儲設備訪問失敗的失敗報告,修改第一存儲設備和第二存儲設備之間的鏡像方向;以及通知単元24,配置為發出路徑修改通知,要求更改到第二存儲設備的路徑設置。與鏡像管理裝置20相互通信的是路徑管理裝置30。在一個實施例中,路徑管理裝置30可以基於現有的路徑管理裝置,例如SDD,來進行功能擴展。SDD(Multipath SubsystemDevice Driver)是ー種支持多路徑(Multipath)配置環境的工具,提供從主機到存儲設備的驅動和連接。通過SDD,主機可以通過多個數據通道同時訪問同一個邏輯単元LUN。或者,路徑管理裝置30也可以完全獨立於現有路徑管理裝置而實現。為了協助進行存儲數據的切換,路徑管理裝置30進ー步配置為圖5所示的結構。圖5示出根據本發明一個實施例的路徑管理裝置的示意框圖。如圖所示,路徑管理裝置30包括通信単元32,配置為在按照路徑表訪問第一存儲設備失敗時,發送訪問失敗報告,並接收路徑修改通知;以及路徑修改単元34,配置為根據獲得的路徑修改通知,通過修改路徑表來激活到第二存儲設備的偽路徑,使得第二存儲設備能夠被訪問。下面結合具體例子來描述鏡像管理裝置和路徑管理裝置的具體執行方式。圖6示出在ー個具體例子中鏡像管理裝置和路徑管理裝置的交互示意圖。為了對鏡像關係進行記錄和管理,鏡像管理裝置20中可以包含一個鏡像存儲單元(未示出),用於存儲當前的鏡像關係。另ー方面,路徑管理裝置30可以包含一個路徑表維持單元(未示出),用於維持路徑表,路徑表中記錄指向存儲設備中各個LUN的多個路徑的信息。在圖6的例子中,在第一存儲設備中包含LUN A,在第二存儲設備中包含LUN B。假定最初,第一存儲設備和第二存儲設備之間還未建立同步鏡像關係,並且虛擬機位於第一站點中。這時,由於虛擬機還未開始遷移,路徑管理裝置30位於第一主機中。因此,路徑管理裝置30的路徑表中僅記錄有指向本地連接的LUN A的路徑。此時的路徑表如下所示
DEV#: O DEVICE NAME: hdiskO TYPE: 2107900 ALGORITHM: Load Balance SERIAL: 75022812202 * * indicates the volume where I/O routed to
Path# Adapter/Path Name State Mode Select Errors
0vscsiO/pathO OPEN NORMAL 108583 0
1vscsiO/pathl OPEN NORMAL 108267 0 一旦LUN A和LUN B建立了同步鏡像關係,鏡像管理裝置20中的鏡像存儲單元就會對這樣的信息進行記錄。具體地,鏡像管理裝置20會記錄LUN B的信息以及鏡像的方向,例如,LUN A是主邏輯單元,LUN B是備份邏輯單元,如實線箭頭所示。並且,鏡像管理裝置20會與路徑管理裝置30進行通信,通知其鏡像關係的建立。響應於這樣的通知,路徑管理裝置30中的路徑表維持單元在其路徑表中創建出一個「偽路徑」,也就是指向LUN B的路徑。此時的路徑表如下所示
DEVftO DEVICE NAME: hdiskO TYPE: 2107900 ALGORITHM: Load Balance SESSION: newsession
PRIMARY SERIAL: 75022812202 ** indicates the volume where I/O routed to
Path#Adapter/Path NameStateMode Select Errors
0vscsiO/pathOOPENNORMAL 1085830
1vscsi 0/path IOPENNORMAL 1082670SECONDARY SERIAL: 75022811752
Path#Adapter/Path NameStateModeSelect Errors
2vscsi 0/path2CLOSE INACTIVE〇0
3vscsi 0/path3CLOSEINACTIVE00在上述路徑表中,路徑0/1是到LUN A的路徑(序號75022812202),路徑2/3是到LUN B的路徑(序號75022811752)。由於LUN B和LUN A之間的同步鏡像關係,因此,在一個實施例中,路徑管理裝置30可以將其分組到一起,識別為磁碟hdiskO。由於當前路徑管理裝置30位於第一主機中,與第一存儲設備本地連接,因此這吋,LUN A是可以訪問的(狀態為normal), LUN B不能訪問(狀態為inactive)。因此,指向LUN B的路徑可以稱為偽路徑。隨著虛擬機內存數據的遷移(利用上述的硬體管理裝置),作業系統遷移到第二主機上。由於路徑管理裝置30安裝在虛擬機中,因此也隨著作業系統的遷移轉移到了第二主機上。如上所述,此時,當第二主機通過路徑管理裝置30訪問關聯的存儲設備時,會按照上述路徑表將LUN A識別為主邏輯單元。然而,由於LUN A與第二主機並不是本地連接,這樣的訪問就會失敗。於是,路徑管理裝置30獲得ー個失敗報告,並通過通信単元32將該LUN A訪問失敗的報告發送給鏡像管理裝置20。鏡像管理裝置20接收到LUN A訪問失敗報告之後,從鏡像存儲單元讀取所維持的與LUN A相關的鏡像關係,並通過鏡像修改単元22對其進行修改。更具體而言,在所維持的原有鏡像關係中,LUN A是主邏輯單元,LUN B是備份邏輯單元,數據寫入的方向是從LUNA到LUN B。響應於對LUN A訪問失敗的報告,鏡像修改單元22修改鏡像關係的方向,將LUNB作為主邏輯單元,LUN B作為備份邏輯單元,使得數據從LUN B寫入LUN A,如虛線箭 頭所示。並且,鏡像管理裝置20利用通知単元24向路徑管理裝置30發出路徑修改通知,要求更改到LUN B的路徑設置。於是,路徑管理裝置30中的通信單元32獲取到路徑修改通知,其中包含與LUN B相關的信息。根據該路徑修改通知,路徑修改単元34對原有路徑表進行修改,激活到LUN B的偽路徑,使其能夠被訪問。具體而言,路徑修改単元34進ー步將路徑表修改為如下的形式
權利要求
1.一種切換管理設備,用於在虛擬機的異步遷移中基於虛擬機內存數據的遷移協助進行虛擬機存儲數據的切換,其中所述存儲數據的切換是將存儲數據從第一站點中的第一存儲設備切換到第二站點中的第二存儲設備,其中第一存儲設備和第二存儲設備之間建立有同步鏡像關係,所述切換管理設備包括 通信單元,配置為在按照路徑表訪問第一存儲設備失敗時,發出訪問失敗報告; 鏡像修改單元,配置為響應於所述失敗報告,修改第一存儲設備和第二存儲設備之間的鏡像方向; 通知單元,配置為發出路徑修改通知,要求更改到第二存儲設備的路徑設置; 路徑修改單元,配置為根據所述路徑修改通知,通過修改路徑表來激活到第二存儲設備的路徑,使得第二存儲設備能夠被訪問。
2.根據權利要求I的切換管理設備,還包括鏡像存儲單元,配置為響應於所述同步鏡像關係的建立,存儲所述第一存儲設備和第二存儲設備之間的同步鏡像關係,其中所述第一存儲設備為主存儲設備,第二存儲設備為備份存儲設備,數據從第一存儲設備寫往第二存儲設備。
3.根據權利要求2的切換管理設備,其中鏡像修改單元配置為,修改所述同步鏡像關係中的鏡像方向,使得所述第二存儲設備成為主存儲設備,所述第一存儲設備成為備份存儲設備,數據從第二存儲設備寫往第一存儲設備。
4.根據權利要求2的切換管理設備,還包括路徑表維持單元,配置為與所述鏡像存儲單元通信,從而響應於同步鏡像關係的建立,在路徑表中創建到第二存儲設備的路徑,其中指向第一存儲設備的路徑被設定為可用,指向第二存儲設備的路徑被設定為不可用。
5.根據權利要求4的切換管理設備,其中所述路徑修改單元配置為,根據所述路徑修改通知修改所述路徑表,將指向第一存儲設備的路徑設定為不可用,將指向第二存儲設備的路徑設定為可用。
6.一種硬體管理裝置,用於在虛擬機的異步遷移中協助進行虛擬機內存數據的遷移以作為虛擬機存儲數據切換的基礎,其中所述內存數據的遷移是將內存數據從第一站點中的第一主機遷移到第二站點中的第二主機,其中第一站點還包括第一存儲設備,第二站點還包括第二存儲設備,所述第一存儲設備和第二存儲設備之間建立有同步同步鏡像關係,所述裝置包括 接收單元,配置為接收遷移指令和第二站點的信息; 複製單元,配置為指示第一主機將虛擬機的內存數據複製到所述第一存儲設備中的子邏輯單元,所述子邏輯單元在所述第二存儲設備中存在鏡像邏輯單元; 通知單元,配置為根據所述第二站點的信息發出通知,所述通知用於指示第二主機從所述鏡像邏輯單元讀取內存數據。
7.根據權利要求6的硬體管理裝置,其中所述通知單元利用乙太網發出通知,所述同步同步鏡像關係利用光纖網建立。
8.根據權利要求6的硬體管理裝置,其中所述子邏輯單元的大小與所述虛擬機內存大小相當。
9.根據權利要求6的硬體管理裝置,其中所述複製單元進一步配置為指示第一主機首先複製內存數據中的核心數據,然後複製其餘的補充數據。
10.一種切換管理方法,用於在虛擬機的異步遷移中基於虛擬機內存數據的遷移協助進行虛擬機存儲數據的切換,其中所述存儲數據的切換是將存儲數據從第一站點中的第一存儲設備切換到第二站點中的第二存儲設備,其中第一存儲設備和第二存儲設備之間建立有同步同步鏡像關係,所述方法包括 在按照路徑表訪問第一存儲設備失敗時,發出訪問失敗報告; 響應於所述失敗報告,修改第一存儲設備和第二存儲設備之間的鏡像方向; 發出路徑修改通知,要求更改到第二存儲設備的路徑設置; 根據所述路徑修改通知,通過修改路徑表來激活到第二存儲設備的路徑,使得第二存儲設備能夠被訪問。
11.根據權利要求10的方法,還包括,響應於同步鏡像關係的建立,存儲所述第一存儲設備和第二存儲設備之間的同步鏡像關係,其中所述第一存儲設備為主存儲設備,第二存儲設備為備份存儲設備,數據從第一存儲設備寫往第二存儲設備。
12.根據權利要求11的方法,其中修改第一存儲設備和第二存儲設備之間的鏡像方向包括,修改所述同步鏡像關係中的鏡像方向,使得所述第二存儲設備成為主存儲設備,所述第一存儲設備成為備份存儲設備,數據從第二存儲設備寫往第一存儲設備。
13.根據權利要求11的方法,還包括,響應於同步鏡像關係的建立,在路徑表中創建到第二存儲設備的路徑,其中指向第一存儲設備的路徑被設定為可用,指向第二存儲設備的路徑被設定為不可用。
14.根據權利要求13的方法,其中所述修改路徑表包括,將指向第一存儲設備的路徑設定為不可用,將指向第二存儲設備的路徑設定為可用。
15.一種硬體管理方法,用於在虛擬機的異步遷移中協助進行虛擬機內存數據的遷移以作為虛擬機存儲數據切換的基礎,其中所述內存數據的遷移是將內存數據從第一站點中的第一主機遷移到第二站點中的第二主機,其中第一站點還包括第一存儲設備,第二站點還包括第二存儲設備,所述第一存儲設備和第二存儲設備之間建立有同步同步鏡像關係,所述方法包括 接收遷移指令和第二站點的信息; 指示第一主機將虛擬機的內存數據複製到所述第一存儲設備中的子邏輯單元,所述子邏輯單元在所述第二存儲設備中存在鏡像邏輯單元; 根據所述第二站點的信息發出通知,所述通知用於指示第二主機從所述鏡像邏輯單元讀取內存數據。
16.根據權利要求15的方法,其中所述通知利用乙太網發出,所述同步同步鏡像關係利用光纖網建立。
17.根據權利要求15的方法,其中所述子邏輯單元的大小與所述虛擬機內存大小相當。
18.根據權利要求15的方法,其中指示第一主機將虛擬機的內存數據複製到所述第一存儲設備中的子邏輯單元包括指示第一主機首先複製內存數據中的核心數據,然後複製其餘的補充數據。
全文摘要
本發明提供遷移虛擬機的裝置和方法,其中遷移虛擬機內存數據的裝置包括接收單元,用於接收遷移指令和第二站點的信息;複製單元,用於將內存數據複製到第一存儲設備中的子邏輯單元;通知單元,用於向第二主機發出通知,通知其從第二存儲設備中所述子邏輯單元的鏡像單元讀取數據。還提供了協助切換虛擬機的存儲數據的裝置,通過修改第一存儲設備和第二存儲設備之間的鏡像方向,以及修改與第一存儲設備和第二存儲設備相關的路徑表來實現存儲數據的切換。本發明還提供與上述裝置對應的方法。根據本發明的裝置和方法,利用同步鏡像方式實現虛擬機數據的遷移和切換,從而實時地在不同站點之間遷移虛擬機,而不影響虛擬機及其應用的運行。
文檔編號G06F9/455GK102761566SQ20111010477
公開日2012年10月31日 申請日期2011年4月26日 優先權日2011年4月26日
發明者M·S·弗萊明, 姜鵬, 張昕, 張融 申請人:國際商業機器公司

同类文章

一種新型多功能組合攝影箱的製作方法

一種新型多功能組合攝影箱的製作方法【專利摘要】本實用新型公開了一種新型多功能組合攝影箱,包括敞開式箱體和前攝影蓋,在箱體頂部設有移動式光源盒,在箱體底部設有LED脫影板,LED脫影板放置在底板上;移動式光源盒包括上蓋,上蓋內設有光源,上蓋部設有磨沙透光片,磨沙透光片將光源封閉在上蓋內;所述LED脫影

壓縮模式圖樣重疊檢測方法與裝置與流程

本發明涉及通信領域,特別涉及一種壓縮模式圖樣重疊檢測方法與裝置。背景技術:在寬帶碼分多址(WCDMA,WidebandCodeDivisionMultipleAccess)系統頻分復用(FDD,FrequencyDivisionDuplex)模式下,為了進行異頻硬切換、FDD到時分復用(TDD,Ti

個性化檯曆的製作方法

專利名稱::個性化檯曆的製作方法技術領域::本實用新型涉及一種檯曆,尤其涉及一種既顯示月曆、又能插入照片的個性化檯曆,屬於生活文化藝術用品領域。背景技術::公知的立式檯曆每頁皆由月曆和畫面兩部分構成,這兩部分都是事先印刷好,固定而不能更換的。畫面或為風景,或為模特、明星。功能單一局限性較大。特別是畫

一種實現縮放的視頻解碼方法

專利名稱:一種實現縮放的視頻解碼方法技術領域:本發明涉及視頻信號處理領域,特別是一種實現縮放的視頻解碼方法。背景技術: Mpeg標準是由運動圖像專家組(Moving Picture Expert Group,MPEG)開發的用於視頻和音頻壓縮的一系列演進的標準。按照Mpeg標準,視頻圖像壓縮編碼後包

基於加熱模壓的纖維增強PBT複合材料成型工藝的製作方法

本發明涉及一種基於加熱模壓的纖維增強pbt複合材料成型工藝。背景技術:熱塑性複合材料與傳統熱固性複合材料相比其具有較好的韌性和抗衝擊性能,此外其還具有可回收利用等優點。熱塑性塑料在液態時流動能力差,使得其與纖維結合浸潤困難。環狀對苯二甲酸丁二醇酯(cbt)是一種環狀預聚物,該材料力學性能差不適合做纖

一種pe滾塑儲槽的製作方法

專利名稱:一種pe滾塑儲槽的製作方法技術領域:一種PE滾塑儲槽一、 技術領域 本實用新型涉及一種PE滾塑儲槽,主要用於化工、染料、醫藥、農藥、冶金、稀土、機械、電子、電力、環保、紡織、釀造、釀造、食品、給水、排水等行業儲存液體使用。二、 背景技術 目前,化工液體耐腐蝕貯運設備,普遍使用傳統的玻璃鋼容

釘的製作方法

專利名稱:釘的製作方法技術領域:本實用新型涉及一種釘,尤其涉及一種可提供方便拔除的鐵(鋼)釘。背景技術:考慮到廢木材回收後再加工利用作業的方便性與安全性,根據環保規定,廢木材的回收是必須將釘於廢木材上的鐵(鋼)釘拔除。如圖1、圖2所示,目前用以釘入木材的鐵(鋼)釘10主要是在一釘體11的一端形成一尖

直流氧噴裝置的製作方法

專利名稱:直流氧噴裝置的製作方法技術領域:本實用新型涉及ー種醫療器械,具體地說是ー種直流氧噴裝置。背景技術:臨床上的放療過程極易造成患者的局部皮膚損傷和炎症,被稱為「放射性皮炎」。目前對於放射性皮炎的主要治療措施是塗抹藥膏,而放射性皮炎患者多伴有局部疼痛,對於止痛,多是通過ロ服或靜脈注射進行止痛治療

新型熱網閥門操作手輪的製作方法

專利名稱:新型熱網閥門操作手輪的製作方法技術領域:新型熱網閥門操作手輪技術領域:本實用新型涉及一種新型熱網閥門操作手輪,屬於機械領域。背景技術::閥門作為流體控制裝置應用廣泛,手輪傳動的閥門使用比例佔90%以上。國家標準中提及手輪所起作用為傳動功能,不作為閥門的運輸、起吊裝置,不承受軸向力。現有閥門

用來自動讀取管狀容器所載識別碼的裝置的製作方法

專利名稱:用來自動讀取管狀容器所載識別碼的裝置的製作方法背景技術:1-本發明所屬領域本發明涉及一種用來自動讀取管狀容器所載識別碼的裝置,其中的管狀容器被放在循環於配送鏈上的文檔匣或託架裝置中。本發明特別適用於,然而並非僅僅專用於,對引入自動分析系統的血液樣本試管之類的自動識別。本發明還涉及專為實現讀