專利名稱::自動調整快照設備的寫入同步復制磁盤空間大小的方法
技術領域:
:本發明涉及一種存儲系統管理方法,尤其涉及一種存儲系統的快照設備管理方法。
背景技術:
:基于Linux系統的邏輯巻管理(LogicalVolumeManagement,LVM)通過在輸入/輸出(I/o)子系統中增加一個額外層來實現,這個加在文件系統和實體磁盤驅動之間的層稱為邏輯巻設備驅動層(LogicalVolumeDeviceDriver,LVDD。通過邏輯巻設備驅動層,上層的文件系統或其它應用獲得了一個對磁盤或分區虛擬視圖。請參考圖1,邏輯巻管理在多個同一類型存儲設備(如,硬盤、RAID設備)上開啟由多個實體區塊(PhysicalExtent,PE)140組成的實體巻(PhysicalVolume,PV)120,并將這些實體巻120通過串聯或者分條(Stripe)的方式組合成巻組(VolumeGroup,VG)100。將巻組100劃分為-個或多個邏輯巻(LogicalVolume,LV)后,就可以如使用/盤符/分區(/disk/partition)—樣使用/設備/巻組名/邏輯巻名(/device/vg-name/lv-name)來訪問邏輯巻。邏輯巻管理可以動態地修改存儲空間的大小,其上的數據亦不會丟失,且不需要重新啟動計算機。為了保證數據的安全性,邏輯巻管理采用了快照(Snapshot)機制。快照技術為一種針對包括硬盤、邏輯磁盤等區塊設備的備份方式,開啟快照的設備稱作原區塊設備,開啟出的快照是與原區塊設備相關聯的區塊設備,稱作快照設備。原區塊設備和快照設備的描述結構都保存在系統隨機存取存儲器(Random-accessmemory,簡稱RAM)中,快照設備本身也需要使用一定的實體存儲空間。一般開啟快照時需要指定原區塊設備、快照實際容量大小以及快照設備本身使用的存儲設備,快照設備的邏輯存儲容量為原區塊設備的大小。在快照設備上存儲數據并劃分空間的最小單位為數據區塊(chunk),一般大小為64k。快照并不是對原區塊設備存儲的數據的完全備份,而是以數據區塊為單位對原區塊設備進行劃分,直到原區塊設備的數據需要被修改時,才將需要修改的數據區塊的數據復制到快照設備,這種技術被稱為"寫入同步復制(copy漏on-write,COW)"技術。快照被開啟時會被劃分為多個實體區塊(通常以M為單位),每個實體區塊被劃分為多個數據區塊。每個實體區塊的第一個數據區塊用以記錄舊數據區土央(oldchunk)和新數據區塊(newchunk)的對應關系(即,exceptiontable),其余數據區塊則用以存放寫入同步復制數據。請參考圖2,計算機啟動時,系統內核讀取硬盤上的exceptiontable以在存儲器上開啟一個雜湊(hash)表。當在步驟200接收到用戶發送的寫入請求,需要進行寫入同步復制(COW)操作時,首先在步驟202判斷是否存在與寫入請求數據區塊相應的快照。當不存在快照時,在步驟210繼續發送寫入請求。否則,在步驟204遍歷存儲器中的雜湊表,在步驟206判斷是否在雜湊表中査找到對應項。當在雜湊表中査找到對應項時,說明此寫入請求的數據區塊已完成寫入同步復制操作,因此在步驟210繼續發送寫入請求;否則,在步驟208進行寫入同步復制操作,然后在步驟210繼續發送寫入請求。因此公知技術的主要缺點如下每修改一次數據區塊,就需要進行一次寫入同步復制操作,而寫入同步復制操作采用了同步輸入/輸出(i/o)操作,即需要等此寫入操作完成,系統才會進行后面的操作。因此,當有大量寫入請求發生時,寫入同步復制機制會導致大量輸入/輸出(I/0)操作,極大地降低了系統性能。快照開啟后,數據區塊的大小不可以改變。如果數據區塊設置過小,在處理大容量寫入請求時會導致大量輸入/輸出操作,極大降低系統性能;反之,在處理小容量寫入請求時會導致磁盤空間的浪費,并降低系統處理速度。
發明內容為了解決上述公知技術中的問題與缺陷,本發明的目的在于提供一種自動調整快照設備的寫入同步復制磁盤空間大小的方法。本發明所提供的一種自動調整快照設備的寫入同步復制磁盤空間大小的方法,包含以下步驟a初始化一個快照設備的一個第一磁盤空間,對第一磁盤空間的數據區塊進行寫入同步復制操作;b判斷一個寫入請求的數據區塊序號是否位于第一磁盤空間;c當寫入請求的數據區塊序號位于第一磁盤空間時,繼續維護第一磁盤空間;以及d當寫入請求的數據區塊序號不位于第一磁盤空間時,初始化一個第二磁盤空間,此第二磁盤空間的數據區塊數目與第一磁盤空間中最大連續數據區塊數目相同,并對第二磁盤空間的數據區塊進行寫入同步復制操作。其中該寫入請求的數據區塊數量不大于該快照設備的操作系統定義的磁盤輸入輸出的最大值。其中第一磁盤空間的數據結構包含起始序號數據變量、當前起始序號數據變量、當前最后序號數據變量、當前最大數數據變量以及最大數數據變量。其中第一磁盤空間的起始序號的初始值為0,當前起始序號的初始值為0,當前最后序號的初始值為0,當前最大數的初始值為l,最大數的初始值為1。其中步驟b進一步包含計算出第一磁盤空間的起始序號的值與最大數的值相加的結果;判斷寫入請求的數據區塊序號是否大于此結果。其中步驟C進一步包含判斷寫入請求的數據區塊序號是否等于第一磁盤空間的當前最后序號的值加1;當寫入請求的數據區塊序號等于第一磁盤空間的當前最后序號的值加1時,將第一磁盤空間的當前最后序號的值加1;以及否則,計算出第一磁盤空間的當前最后序號的值減去當前起始序號的值的結果,將此結果與第一磁盤空間的當前最大數的值中較大值賦值給第一磁盤空間的當前最大數,并將寫入請求的數據區塊序號賦值該第一磁盤空間的當前起始序號和當前最后序號。其中第二磁盤空間的數據結構與第一磁盤空間的數據結構相同。其中步驟d進一步包含判斷寫入請求的數據區塊序號是否等于第一磁盤空間的當前最后序號的值加1;當寫入請求的數據區塊序號等于第一磁盤空間的當前最后序號的值加1時,將第一磁盤空間的當前最后序號的值加1,并對第一磁盤空間的當前最后序號的值對應的數據區塊進行寫入同步復制操作;否則,將寫入請求的數據區塊序號賦值給第二磁盤空間的起始序號、當前起始序號以及當前最后序號,計算出第一磁盤空間的當前最后序號的值減去當前起始序號的值的結果,將此結果與第一磁盤空間的當前最大數的值中較大值賦值給第二磁盤空間的最大數;以及從第二磁盤空間的起始序號的值對應的數據區塊開始,對與第二磁盤空間的最大數的值相同數量的數據區塊進行寫入同步復制操作。綜上所述,本發明可以自動調整寫入同步復制磁盤空間的大小,同時將較多連續的寫入同步復制操作集中于一次完成,通過這種連續、集中、突發式請求,極大提高了系統性能。圖1為公知技術的巻組組成結構的方塊圖2為公知技術的寫入請求的快照處理流程圖3和圖4為本發明的自動調整快照設備的寫入同步復制磁盤空間大小的方法流程圖;以及圖5為第一磁盤空間在不同時刻的狀態方塊圖。其中,附圖標記說明如下-100巻組120實體巻140實體區塊500第一磁盤空間502第一連續數據區塊區域504第二連續數據區塊區域步驟200接收用戶發送的寫入請求步驟202是否有快照步驟204遍歷存儲器中的雜湊表步驟206是否找到對應項步驟208進行寫入同步復制操作步驟210繼續發送寫入請求步驟300初始化一個快照設備的第一磁盤空間,對第一磁盤空間的數據區塊進行寫入同步復制操作步驟302寫入請求的數據區塊序號是否大于第一磁盤空間的起始序號的值加上最大數的值步驟304寫入請求的數據區塊序號是否等于第一磁盤空間的當前最后序號的值加1步驟306將第一磁盤空間的當前最后序號的值加1步驟308計算出第一磁盤空間的當前最后序號的值減去當前起始序號的值的結果步驟310將此結果與第一磁盤空間的當前最大數的值中較大值賦值給第一磁盤空間的當前最大數步驟312將寫入請求的數據區塊序號賦值給第一磁盤空間的當前起始序號和當前最后序號步驟400寫入請求的數據區塊序號是否等于第一磁盤空間的當前最后序號的值加1步驟402將第一磁盤空間的當前最后序號的值加1步驟404對第一磁盤空間的當前最后序號的值對應的數據區塊進行寫入同步復制操作步驟406將寫入請求的數據區塊序號賦值給第二磁盤空間的起始序號、當前起始序號以及當前最后序號步驟408計算出第一磁盤空間的當前最后序號的值減去當前起始序號的值的結果步驟410將此結果與第一磁盤空間的當前最大數的值中較大值賦值給第二磁盤空間的最大數步驟412對第二磁盤空間的數據區塊進行寫入同步復制操作具體實施例方式以下,將結合附圖部分對本發明的優選實施方式作詳細說明。圖3和圖4所示為本發明的自動調整快照設備的寫入同步復制磁盤空間大小的方法。其中,字母A表示寫入請求的數據區塊序號大于第一磁盤空間的起始序號的值加上最大數的值時的處理流程。如圖2所示的公知技術的寫入請求處理的快照處理流程,當雜湊表中不存在與寫入請求的數據區塊對應的信息,需要在步驟208進行寫入同步復制操作時,即可用本發明以替代公知的處理方法。首先,在步驟300初始化一個快照設備的第一磁盤空間,對第一磁盤空間進行寫入同步復制(COW)操作。初始化后的第一磁盤空間的數據結構包含起始序號數據變量、當前起始序號數據變量、當前最后序號數據變量、當前最大數數據變量以及最大數數據變量。例如,采用以下描述的結構<formula>complexformulaseeoriginaldocumentpage9</formula>其中,起始序號數據變量(org一window一chunk)用以表示第一磁盤空間的第一個數據區塊序號,初始值為0;當前起始序號數據變量(tmp_Wind0w_0rg_ChUnk)ffl以表示第一磁盤空間中正在維護的連續數據區塊的第一個數據區塊的序號,初始值為0;當前最后序號數據變量Ctmp_window—last一chunk)用以表示正在維護的連續數據區塊的最后一個數據區塊的序號,即上一次寫入請求的數據區塊序號,初始值為0;當前最大數數據變量(tmp—max—windows)用以表示第一磁盤空間中當前最大連續數據區塊數,初始值為1;最大數數據變量(last—windows—chunks)用以表示上一磁盤空間中最大連續數據區塊數,初始值為1,其與起始序號的值相加即為第--磁盤空間所維護的最大數據區塊序號。當接收到用戶發送的寫入請求,需要進行寫入同步復制操作時,判斷寫入請求的數據區塊序號是否位于第一磁盤空間,即計算出第一磁盤空間的起始序號的值與最大數的值相加的結果,并在步驟302判斷寫入請求的數據區塊序號是否大于此結果。當寫入請求的數據區塊序號小于或等于此兩者相加的結果時,即表明寫入請求的數據區塊序號位于第一磁盤空間。此時,在步驟304繼續判斷寫入請求的數據區塊序號是否等于第一磁盤空間的當前最后序號的值加1,即判斷寫入請求的數據區塊序號是否與當前正在維護的連續數據區塊相連續。當寫入請求的數據區塊序號等于第一磁盤空間的當前最后序號的值加1時,表明寫入請求的數據區塊序號與第一磁盤空間中正在維護的連續數據區塊相連續。因為第一磁盤空間在初始化時已完成寫入同步復制操作,所以僅需要在步驟306將第一磁盤空間的當前最后序號的值加1。當寫入請求的數據區塊序號不等于第一磁盤空間的當前最后序號的值加1時,表明寫入請求的數據區塊序號與第一磁盤空間中正在維護的連續數據區塊不相連續。因此,在步驟308先計算出第一磁盤空間的當前最后序號的值減去當前起始序號的值的結果,在步驟310將此結果與第一磁盤空間的當前最大數的值中較大值賦值給第一磁盤空間的當前最大數,從而更新第一磁盤空間的當前最大數中存儲的當前最大連續數據區塊數。接著在步驟312將寫入請求的數據區塊序號賦值給第一磁盤空間的當前起始序號和當前最后序號,以在第一磁盤空間開啟另一個連續數據區塊區域。當寫入請求的數據區塊序號大于第一磁盤空間的起始序號的值與最大數的值相加的結果時,即表明寫入請求的數據區塊序號不位于第一磁盤空間。此時,在步驟400繼續判斷寫入請求的數據區塊序號是否等于第一磁盤空間的當前最后序號的值加1,即判斷寫入請求的數據區塊序號是否與當前正在維護的連續數據區塊相連續。當寫入請求的數據區塊序號等于第一磁盤空間的當前最后序號的值加1時,表明寫入請求的數據區塊序號與第一磁盤空間中正在維護的連續數據區塊相連續。但寫入請求的數據區塊序號不位于第一磁盤空間,即寫入請求的數據區塊未進行寫入同步復制操作,所以在步驟402先將第一磁盤空間的當前最后序號的值加1,接著在步驟404對第一磁盤空間的當前最后序號的值對應的數據區塊進行寫入同步復制操作,從而擴展了第一磁盤空間的大小。當寫入請求的數據區塊序號不等于第一磁盤空間的當前最后序號的值加1時,表明寫入請求的數據區塊序號與第一磁盤空間中正在維護的連續數據區塊不相連續,因而需要初始化一個第二磁盤空間。第二磁盤空間加數據結構與第一磁盤空間相同,其初始化時數據區塊數目為第一磁盤空間的最大連續數據區塊數目。在第二磁盤空間初始化過程時,在步驟406先將寫入請求的數據區塊序號賦值給第二磁盤空間的起始序號、當前起始序號以及當前最后序號。接著在步驟408計算出第一磁盤空間的當前最后序號的值減去當前起始序號的值的結果,在步驟410將此結果與第一磁盤空間的當前最大數的值中較大值賦值給第二磁盤空間的最大數。最后,從第二磁盤空間的起始序號的值對應的數據區塊開始,在步驟412對與第二磁盤空間的最大數的值相同數目的數據區塊進行寫入同步復制操作。由以上描述可知,當寫入請求的數據區塊序號不位于第一磁盤空間,但與第一磁盤空間的最后序號的值加1相等時,即可實現第一磁盤空間的大小的自動調整。而將第一磁盤空間、第二磁盤空間的全部數據區塊的寫入同步復制操作集中于一次完成,則可以通過這種連續、集中、突發式請求,極大提高系統性能。請參考圖5,其為第一磁盤空間500在不同時刻的狀態方塊圖。初始化后的第一磁盤空間500,其起始序號、當前起始序號和當前最后序號均為同一值,即為第一磁盤空間500的第一個數據區塊的序號。而當前最大數的值為起始值1,最大數的值也為初始值1,即第一磁盤空間500僅包含一個數據區塊。時刻1的第一磁盤空間500,包含一個第一連續數據區塊區域502。此時,第一磁盤空間500的起始序號的值沒有變化,而當前起始序號的值為第一連續數據區塊區域502的第一個數據區塊的序號,當前最后序號的值為第一連續數據區塊區域502的最后一個數據區塊的序號,即為上一次寫入請求的數據區塊序號。當前最大數的值仍為初始值l。時刻2的第一磁盤空間500包含兩個連續數據區塊區域,第一連續數據區塊區域502和第二連續數據區塊區域504。第一磁盤空間500的起始序號的值仍沒有變化,為第一磁盤空間500的第一個數據區塊的序號。當前起始序號的值則變為第二連續數據區塊區域504的第一個數據區塊的序號,當前最后序號的值變為第二連續數據區塊區域504的最后一個數據區塊的序號,當前最大數的值為第一連續數據區塊區域502的數據區塊數目。雖然本發明以前述的優選實施方式公開如上,然而其并非用以限制本發明。所屬領域的技術人員應當意識到在不脫離本發明所附的權利要求所公開的本發明的范圍和精神的情況下,所作的變更與修飾,均屬本發明的專利保護范圍。關于本發明所界定的保護范圍請參考所附的權利要求書。權利要求1.一種自動調整快照設備的寫入同步復制磁盤空間大小的方法,該方法包含以下步驟a初始化一快照設備的一第一磁盤空間,對該第一磁盤空間的數據區塊進行寫入同步復制操作;b判斷一寫入請求的數據區塊序號是否位于該第一磁盤空間;c當該寫入請求的數據區塊序號位于該第一磁盤空間時,繼續維護該第一磁盤空間;以及d當該寫入請求的數據區塊序號不位于該第一磁盤空間時,初始化一第二磁盤空間,該第二磁盤空間的數據區塊數目與該第一磁盤空間中最大連續數據區塊數目相同,并對該第二磁盤空間的數據區塊進行寫入同步復制操作。2.如權利要求1所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中該寫入請求的數據區塊數量不大于該快照設備的操作系統定義的磁盤輸入輸出的最大值。3.如權利要求1所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中該第一磁盤空間的數據結構包含一起始序號數據變量、一當前起始序號數據變量、一當前最后序號數據變量、一當前最大數數據變量以及一最大數數據變量。4.如權利要求3所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中該第一磁盤空間的起始序號數據變量的初始值為0,該當前起始序號數據變量的初始值為0,該當前最后序號數據變量的初始值為0,該當前最大數數據變量的初始值為1,該最大數數據變量的初始值為1。5.如權利要求3所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中步驟b進一步包含計算出該第一磁盤空間的起始序號數據變量的值與該最大數數據變量的值相加的一結果;以及判斷該寫入請求的數據區塊序號是否大于該結果。6.如權利要求3所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中步驟c進一步包含-判斷該寫入請求的數據區塊序號是否等于該第一磁盤空間的當前最后序號數據變量的值加l;當該寫入請求的數據區塊序號等于該第一磁盤空間的當前最后序號數據變量的值加1時,將該第一磁盤空間的當前最后序號數據變量的值加h以及否則,計算出該第一磁盤空間的當前最后序號數據變量的值減去該當前起始序號數據變量的值的一結果,將該結果與該第一磁盤空間的當前最大數數據變量的值中較大值賦值給該第一磁盤空間的當前最大數數據變量,并將該寫入請求的數據區塊序號賦值給該第一磁盤空間的當前起始序號數據變量和該當前最后序號數據變量。7.如權利要求3所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中該第二磁盤空間的數據結構與該第一磁盤空間的數據結構相同。8.如權利要求7所述的自動調整快照設備的寫入同步復制磁盤空間大小的方法,其中步驟d進一步包含判斷該寫入請求的數據區塊序號是否等于該第一磁盤空間的當前最后序號數據變量的值加1;當該寫入請求的數據區塊序號等于該第一磁盤空間的當前最后序號數據變量的值加1時,將該第一磁盤空間的當前最后序號數據變量的值加1,并對該第一磁盤空間的當前最后序號數據變量的值對應的數據區塊進行寫入同步復制操作;否則,將該寫入請求的數據區塊序號賦值給該第二磁盤空間的一起始序號數據變量、一當前起始序號數據變量以及一當前最后序號數據變量,計算出該第一磁盤空間的當前最后序號數據變量的值減去該當前起始序號數據變量的值的一結果,將該結果與該第一磁盤空間的當前最大數數據變量的值中較大值賦值給該第二磁盤空間的一最大數數據變量;以及從該第二磁盤空間的起始序號數據變量的值對應的數據區塊開始,對與該第二磁盤空間的最大數數據變量的值相同數量的數據區塊進行寫入同步復制操作。全文摘要一種自動調整快照設備的寫入同步復制磁盤空間大小的方法,初始化快照設備的第一磁盤空間,對第一磁盤空間的數據區塊進行寫入同步復制操作;判斷寫入請求的數據區塊序號是否位于第一磁盤空間;當寫入請求的數據區塊序號位于第一磁盤空間時,維護第一磁盤空間;當寫入請求的數據區塊序號不位于第一磁盤空間時,初始化第二磁盤空間,第二磁盤空間的數據區塊數目與第一磁盤空間中最大連續數據區塊數目相同,并對第二磁盤空間的數據區塊進行寫入同步復制操作。本發明可以自動調整寫入同步復制磁盤空間的大小,同時將較多連續的寫入同步復制操作集中于一次完成,通過這種連續、集中、突發式請求,極大提高了系統性能。文檔編號G06F12/02GK101201796SQ20061016880公開日2008年6月18日申請日期2006年12月14日優先權日2006年12月14日發明者劉文涵,義李,郭建發,陳玄同申請人:英業達股份有限公司