本申請涉及計算機技術(shù)領(lǐng)域,尤其涉及一種虛擬機內(nèi)存回收方法及裝置。
背景技術(shù):
隨著計算機技術(shù)和互聯(lián)網(wǎng)的快速發(fā)展,操作系統(tǒng)虛擬化技術(shù)日益成熟,虛擬化系統(tǒng)允許多個操作系統(tǒng)并發(fā)運行在同一臺物理主機(以下簡稱物理機)上,所述多個操作系統(tǒng)使用相同的硬件且彼此互不影響。然而,不同的計算機硬件資源在使用時有著不同的特點。對于中央處理器CPU和輸入輸出(I/O)等天然的時分復(fù)用型資源,在使用完畢后,這些資源由虛擬機監(jiān)控器(英文簡稱為VMM,英文全稱為Virtual Machine Monitor)收回,不會處于繼續(xù)使用的狀態(tài)。但對于內(nèi)存等空間型資源來說,虛擬機第一次使用某個內(nèi)存頁時,會向VMM申請資源,但實際的內(nèi)存使用情況VMM無法感知,也無法釋放掉未使用的內(nèi)存頁,這會造成一些不必要的頁面交換和頁面合并的開銷,影響虛擬機的性能。
現(xiàn)有技術(shù)中,內(nèi)核虛擬機(英文簡稱為KVM,英文全稱為Kenel-based Virtual Machine)為了簡化虛擬機資源的管理,把虛擬機抽象成了系統(tǒng)中的一個進程,采用峰值分配的方法限定虛擬機內(nèi)存分配的上限。這種分配方式會因為內(nèi)存分配給虛擬機后,內(nèi)存資源占而不用造成一些不必要的損耗,影響虛擬機的性能。
技術(shù)實現(xiàn)要素:
本申請實施例提供了一種虛擬機內(nèi)存回收方法及裝置,可以有效回收虛擬機占用的內(nèi)存資源,實現(xiàn)內(nèi)存資源的高效時分復(fù)用,提高系統(tǒng)運行效率。
為此,本申請實施例提供如下技術(shù)方案:
第一方面,本申請實施例提供了一種虛擬機內(nèi)存回收方法,包括:監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存;回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息。
在一些實施方式中,所述監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存包括:利用虛擬機空閑內(nèi)存鏈表記錄內(nèi)存使用狀態(tài),根據(jù)所述空閑內(nèi)存鏈表記錄確定處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述處于未使用狀態(tài)的內(nèi)存為通過匿名映射方式分配給虛擬機的內(nèi)存。
在一些實施方式中,所述處于未使用狀態(tài)的內(nèi)存為分配時間大于第一設(shè)定閾值且使用頻率低于第二設(shè)定閾值的內(nèi)存。
在一些實施方式中,所述方法還包括:為首次分配給虛擬機且處于未使用狀態(tài)的內(nèi)存設(shè)置第一標志位;所述根據(jù)所述空閑內(nèi)存鏈表記錄確定處于未使用狀態(tài)的內(nèi)存包括:將除設(shè)置第一標志位之外的未使用內(nèi)存確定為處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息包括:鎖定所述處于未使用狀態(tài)的內(nèi)存,將所述內(nèi)存進行置零處理,釋放所述內(nèi)存;更新內(nèi)存分配信息,解鎖所述內(nèi)存,以便于重新分配所述內(nèi)存。
第二方面,本申請實施例提供了一種虛擬機內(nèi)存回收裝置,包括:確定模塊,用于監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存;回收模塊,用于回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息。
在一些實施方式中,所述確定模塊具體用于:利用虛擬機空閑內(nèi)存鏈表記錄內(nèi)存使用狀態(tài),根據(jù)所述空閑內(nèi)存鏈表記錄確定處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述回收模塊具體用于:鎖定所述處于未使用狀態(tài)的內(nèi)存,將所述內(nèi)存進行置零處理,釋放所述內(nèi)存;更新內(nèi)存分配信息,解鎖所述內(nèi)存,以便于重新分配所述內(nèi)存。
第三方面,本申請實施例提供了一種用于虛擬機內(nèi)存回收的裝置,包括有存儲器,以及一個或者一個以上的程序,其中一個或者一個以上程序存儲于存儲器中,且經(jīng)配置以由一個或者一個以上處理器執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存;回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息。
本申請實施例提供的虛擬機內(nèi)存回收方法及裝置,可以監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存,并回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息,以便重新分配回收的內(nèi)存。由此,可以有效地對回收分配給虛擬機占而不用的內(nèi)存,實現(xiàn)內(nèi)存資源的高效時分復(fù)用,提高系統(tǒng)的運行效率。
附圖說明
為了更清楚地說明本申請實施例或現(xiàn)有技術(shù)中的技術(shù)方案,下面將對實施例或現(xiàn)有技術(shù)描述中所需要使用的附圖作簡單地介紹,顯而易見地,下面描述中的附圖僅僅是本申請中記載的一些實施例,對于本領(lǐng)域普通技術(shù)人員來講,在不付出創(chuàng)造性勞動的前提下,還可以根據(jù)這些附圖獲得其它的附圖。
圖1為本申請實施例提供的虛擬機內(nèi)存回收方法示意圖;
圖2為本申請實施例提供的虛擬機內(nèi)存回收架構(gòu)示意圖;
圖3為本申請實施例提供的虛擬機內(nèi)存回收裝置示意圖;
圖4為本申請實施例提供的用于虛擬機內(nèi)存回收的裝置的示意圖。
具體實施方式
本申請實施例提供了一種虛擬機內(nèi)存回收方法及裝置,可以有效回收虛擬機占用的內(nèi)存資源,實現(xiàn)內(nèi)存資源的高效時分復(fù)用,提高系統(tǒng)運行效率。
為了使本技術(shù)領(lǐng)域的人員更好地理解本申請方案,下面將結(jié)合本申請實施例中的附圖,對本申請實施例中的技術(shù)方案進行清楚、完整地描述,顯然,所描述的實施例僅是本申請一部分實施例,而不是全部的實施例?;诒旧暾堉械膶嵤├绢I(lǐng)域普通技術(shù)人員在沒有做出創(chuàng)造性勞動前提下所獲得的所有其他實施例,都屬于本申請保護的范圍。
在本申請實施例中使用的術(shù)語是僅僅出于描述特定實施例的目的,而非旨在限制本申請。在本申請實施例和所附權(quán)利要求書中所使用的單數(shù)形式的“一種”、“所述”和“該”也旨在包括多數(shù)形式,除非上下文清楚地表示其他含義。還應(yīng)當理解,本文中使用的術(shù)語“和/或”是指并包含一個或多個相關(guān)聯(lián)的列出項目的任何或所有可能組合。
其中,本申請實施例涉及的技術(shù)術(shù)語“物理機”一般用于表示物理實體計算機,為虛擬機提供硬件環(huán)境。
其中,本申請實施例涉及的技術(shù)術(shù)語“虛擬機”(英文全稱為Virtual Machine)一般指通過軟件模擬的具有完整硬件系統(tǒng)功能的、運行在一個完全隔離環(huán)境中的完整計算機系統(tǒng)。一般地,通過物理機和虛擬機的配合,一臺計算機上可以安裝上多個操作系統(tǒng),并且多個操作系統(tǒng)間互不影響。
下面將結(jié)合附圖1至附圖2對本申請示例性實施例示出的虛擬機內(nèi)存回收方法進行介紹。
參見圖1,為本申請一實施例提供的虛擬機內(nèi)存回收方法流程圖。如圖1所示,可以包括:
S101,監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存。
在本申請具體實現(xiàn)時,可以監(jiān)控虛擬機(也可以稱之為客戶機)內(nèi)存使用狀態(tài),并可以回收虛擬機中處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述處于未使用狀態(tài)的內(nèi)存為通過匿名映射方式分配給虛擬機且處于未使用狀態(tài)的內(nèi)存。以Linux操作系統(tǒng)為例進行說明。在Linnux系統(tǒng)中中,一般有兩種內(nèi)存申請方式,分別對應(yīng)mmap(一般用于將一個文件或者對象映射到內(nèi)存)和brk(一般用于調(diào)用動態(tài)內(nèi)存)兩個系統(tǒng)調(diào)用。其中,mmap用于將硬盤上的文件映像加載到內(nèi)存,常用于加載程序和文件,是緩存機制的重要環(huán)節(jié)。Brk所申請的內(nèi)存是匿名映射的內(nèi)存,用于程序動態(tài)申請內(nèi)存的分配,與緩存無關(guān),此類內(nèi)存大量存在于各種應(yīng)用程序的內(nèi)存映射中,可以被回收的也是這部分內(nèi)存。虛擬機向物理機申請內(nèi)存成功,若使用完畢所述內(nèi)存,在虛擬機內(nèi)部釋放掉內(nèi)存后,這部分內(nèi)存就處于未使用狀態(tài)?,F(xiàn)有技術(shù)中,物理機并不能夠感知虛擬機內(nèi)部內(nèi)存的使用狀態(tài)。在本申請中,可以監(jiān)控虛擬機的內(nèi)存使用狀態(tài),并對處于未使用狀態(tài)的內(nèi)存進行分配。具體地,可以通過安裝在虛擬機內(nèi)部的驅(qū)動程序,收集整理處于未使用狀態(tài)的內(nèi)存,并可以通過一定的篩選機制,去除剛分配但未使用的內(nèi)存部分,確定已被虛擬機使用過但當前不再使用的內(nèi)存,并通知物理機回收所述已被虛擬機使用過但當前不再使用的內(nèi)存,并對內(nèi)存資源進行再分配。
具體實現(xiàn)時,可以利用虛擬機空閑內(nèi)存鏈表記錄內(nèi)存使用狀態(tài),根據(jù)所述空閑內(nèi)存鏈表記錄確定處于未使用狀態(tài)的內(nèi)存。舉例說明,所述虛擬機空閑內(nèi)存鏈表可以記錄分配給虛擬機的內(nèi)存的信息。所述內(nèi)存的信息可以包括分配給虛擬機的內(nèi)存的地址、內(nèi)存的使用狀態(tài)以及內(nèi)存是否回收等信息。其中,可以通過記錄內(nèi)存的訪問頻率,將訪問頻率小于第二設(shè)定閾值的內(nèi)存標記為處于未使用狀態(tài)。當然,也可以通過其他方式確定出演未使用狀態(tài)的內(nèi)存。在內(nèi)存信息發(fā)生改變時,本申請實施例可以通過增量更新的方式更新所述虛擬機空閑內(nèi)存鏈表的信息。
在一些實施方式中,為了避免剛分配給虛擬機但未使用的內(nèi)存被回收,可以設(shè)置所述處于未使用狀態(tài)的內(nèi)存為分配時間大于第一設(shè)定閾值且使用頻率低于第二設(shè)定閾值的內(nèi)存。通過所述設(shè)置,可以排除剛分配未使用的內(nèi)存,由此實現(xiàn)內(nèi)存資源的有效利用。當然,在一些實施方式中,還可以采用其他方式避免剛分配給虛擬機但未使用的內(nèi)存被回收。例如,可以為首次分配給虛擬機且處于未使用狀態(tài)的內(nèi)存設(shè)置第一標志位。在確定處于未使用狀態(tài)的內(nèi)存時,將除設(shè)置第一標志位之外的未使用內(nèi)存確定為處于未使用狀態(tài)的內(nèi)存。
在具體實現(xiàn)時,可以由虛擬機內(nèi)部的驅(qū)動模塊監(jiān)控虛擬機內(nèi)存使用狀態(tài)。在內(nèi)存資源緊張時,被標記為處于未使用狀態(tài)的內(nèi)存,不論其是否真實占用物理機的物理內(nèi)存頁面,都可以通知VMM,對其進行釋放。
S102,回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息。
在本申請具體實現(xiàn)時,所述回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息包括:鎖定所述處于未使用狀態(tài)的內(nèi)存,將所述內(nèi)存進行置零處理,釋放所述內(nèi)存;更新內(nèi)存分配信息,解鎖所述內(nèi)存,以便于重新分配所述內(nèi)存。
舉例說明,對于已經(jīng)記錄的處于未使用狀態(tài)、需要釋放的物理內(nèi)存,出于安全的考慮,可以首先使用down_write函數(shù)對該區(qū)間內(nèi)存執(zhí)行鎖定操作。執(zhí)行鎖定操作可以有效避免對所述內(nèi)存的訪問出錯。進一步的,在釋放物理內(nèi)存頁面前可以先對該區(qū)域內(nèi)存執(zhí)行置零處理,使所述內(nèi)存恢復(fù)到原始狀態(tài),然后對所述內(nèi)存執(zhí)行釋放操作。在釋放操作后,可以通過物理機內(nèi)存管理單元及時更新物理機的塊表,所述塊表一般用于記錄內(nèi)存分配信息。最后用up_write函數(shù)解除對該內(nèi)存區(qū)域的鎖定,從而實現(xiàn)了與其他超量使用內(nèi)存策略的兼容。
參見圖2,為本申請一實施例提供的內(nèi)存回收架構(gòu)示意圖。如圖2所示,物理機內(nèi)存管理單元用于分配內(nèi)存給虛擬機(又可以稱之為客戶機)。虛擬機內(nèi)部已經(jīng)使用的內(nèi)存釋放后即成為已經(jīng)分配處于未使用狀態(tài)的內(nèi)存。KVM(VVM的一種)模塊可以收集虛擬機中處于未使用狀態(tài)的內(nèi)存,并在滿足第一設(shè)定條件時釋放所述內(nèi)存,由物理機內(nèi)存管理單元對釋放的內(nèi)存進行重新分配。所述第一設(shè)定條件可以為確定內(nèi)存資源緊張時,例如內(nèi)存占用大于設(shè)定閾值時。所述第一設(shè)定條件可以為確定內(nèi)存超量占用時,例如分配給虛擬機的內(nèi)存總量大于設(shè)定閾值。具體的條件可以是非常靈活的,在此不進行限定。
在本申請一個具體實施場景中,可以在虛擬機中安裝相關(guān)驅(qū)動,并部署修改后的KVM內(nèi)核代碼,其中KVM內(nèi)核修改需要定位釋放的內(nèi)存地址,鎖定內(nèi)存,釋放并解鎖,完成對內(nèi)存資源的釋放。具體實施時,可以部署修改KVM內(nèi)存代碼回收代碼后的KVM環(huán)境,安裝虛擬機操作系統(tǒng),在虛擬機中安裝相關(guān)驅(qū)動,正常運行程序。在系統(tǒng)內(nèi)存資源緊張時會出發(fā)內(nèi)存回收機制,這時,可以通過驅(qū)動監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存,并通知KVM,由KVM回收所述處于未使用狀態(tài)的內(nèi)存,物理機內(nèi)存管理單元更新內(nèi)存分配信息。
當然,以上僅為示例性說明,不視為對本申請的限制。
下面對本申請實施例提供的方法對應(yīng)的設(shè)備進行介紹。
參見圖3,為本申請一實施例提供的虛擬機內(nèi)存回收裝置示意圖。
一種虛擬機內(nèi)存回收裝置300,包括:
確定模塊301,用于監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存.
回收模塊302,用于回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息。
在一些實施方式中,所述確定模塊301具體用于:利用虛擬機空閑內(nèi)存鏈表記錄內(nèi)存使用狀態(tài),根據(jù)所述空閑內(nèi)存鏈表記錄確定處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述確定模塊301具體用于:將所述空閑內(nèi)存鏈表記錄中通過匿名映射方式分配給虛擬機且未使用的內(nèi)存確定為處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述確定模塊301具體用于:根據(jù)所述空閑內(nèi)存鏈表記錄確定分配時間大于第一設(shè)定閾值且使用頻率低于第二設(shè)定閾值的內(nèi)存為處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述裝置還包括:
設(shè)置單元,用于為首次分配給虛擬機且處于未使用狀態(tài)的內(nèi)存設(shè)置第一標志位;
在一些實施方式中,所述確定模塊301具體用于:將除設(shè)置第一標志位之外的未使用內(nèi)存確定為處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,所述回收模塊302具體用于:
鎖定所述處于未使用狀態(tài)的內(nèi)存,將所述內(nèi)存進行置零處理,釋放所述內(nèi)存;更新內(nèi)存分配信息,解鎖所述內(nèi)存,以便于重新分配所述內(nèi)存。
在一些實施方式中,本申請裝置各單元或模塊的設(shè)置可以參照圖1至圖2所示的方法而實現(xiàn),在此不贅述。
參見圖4,是本申請另一實施例提供的虛擬機內(nèi)存回收的裝置的框圖。包括:至少一個處理器401(例如CPU),存儲器402和至少一個通信總線403,用于實現(xiàn)這些裝置之間的連接通信。處理器401用于執(zhí)行存儲器402中存儲的可執(zhí)行模塊,例如計算機程序。存儲器402可能包含高速隨機存取存儲器(RAM:Random Access Memory),也可能還包括非不穩(wěn)定的存儲器(non-volatile memory),例如至少一個磁盤存儲器。一個或者一個以上程序存儲于存儲器中,且經(jīng)配置以由一個或者一個以上處理器401執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:
監(jiān)控虛擬機內(nèi)存使用狀態(tài),確定處于未使用狀態(tài)的內(nèi)存;
回收所述處于未使用狀態(tài)的內(nèi)存,更新內(nèi)存分配信息。
在一些實施方式中,處理器401具體用于執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:
利用虛擬機空閑內(nèi)存鏈表記錄內(nèi)存使用狀態(tài),根據(jù)所述空閑內(nèi)存鏈表記錄確定處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,處理器401具體用于執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:
鎖定所述處于未使用狀態(tài)的內(nèi)存,將所述內(nèi)存進行置零處理,釋放所述內(nèi)存;
更新內(nèi)存分配信息,解鎖所述內(nèi)存,以便于重新分配所述內(nèi)存。
在一些實施方式中,處理器401具體用于執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:
為首次分配給虛擬機且處于未使用狀態(tài)的內(nèi)存設(shè)置第一標志位;
將除設(shè)置第一標志位之外的未使用內(nèi)存確定為處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,處理器401具體用于執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:
將所述空閑內(nèi)存鏈表記錄中通過匿名映射方式分配給虛擬機且未使用的內(nèi)存確定為處于未使用狀態(tài)的內(nèi)存。
在一些實施方式中,處理器401具體用于執(zhí)行所述一個或者一個以上程序包含用于進行以下操作的指令:
根據(jù)所述空閑內(nèi)存鏈表記錄確定分配時間大于第一設(shè)定閾值且使用頻率低于第二設(shè)定閾值的內(nèi)存為處于未使用狀態(tài)的內(nèi)存。
本領(lǐng)域技術(shù)人員在考慮說明書及實踐這里公開的發(fā)明后,將容易想到本申請的其它實施方案。本申請旨在涵蓋本申請的任何變型、用途或者適應(yīng)性變化,這些變型、用途或者適應(yīng)性變化遵循本申請的一般性原理并包括本公開未公開的本技術(shù)領(lǐng)域中的公知常識或慣用技術(shù)手段。說明書和實施例僅被視為示例性的,本申請的真正范圍和精神由下面的權(quán)利要求指出。
應(yīng)當理解的是,本申請并不局限于上面已經(jīng)描述并在附圖中示出的精確結(jié)構(gòu),并且可以在不脫離其范圍進行各種修改和改變。本申請的范圍僅由所附的權(quán)利要求來限制
以上所述僅為本申請的較佳實施例,并不用以限制本申請,凡在本申請的精神和原則之內(nèi),所作的任何修改、等同替換、改進等,均應(yīng)包含在本申請的保護范圍之內(nèi)。
需要說明的是,在本文中,諸如第一和第二等之類的關(guān)系術(shù)語僅僅用來將一個實體或者操作與另一個實體或操作區(qū)分開來,而不一定要求或者暗示這些實體或操作之間存在任何這種實際的關(guān)系或者順序。而且,術(shù)語“包括”、“包含”或者其任何其他變體意在涵蓋非排他性的包含,從而使得包括一系列要素的過程、方法、物品或者設(shè)備不僅包括那些要素,而且還包括沒有明確列出的其他要素,或者是還包括為這種過程、方法、物品或者設(shè)備所固有的要素。在沒有更多限制的情況下,由語句“包括一個……”限定的要素,并不排除在包括所述要素的過程、方法、物品或者設(shè)備中還存在另外的相同要素。本申請可以在由計算機執(zhí)行的計算機可執(zhí)行指令的一般上下文中描述,例如程序模塊。一般地,程序模塊包括執(zhí)行特定任務(wù)或?qū)崿F(xiàn)特定抽象數(shù)據(jù)類型的例程、程序、對象、組件、數(shù)據(jù)結(jié)構(gòu)等等。也可以在分布式計算環(huán)境中實踐本申請,在這些分布式計算環(huán)境中,由通過通信網(wǎng)絡(luò)而被連接的遠程處理設(shè)備來執(zhí)行任務(wù)。在分布式計算環(huán)境中,程序模塊可以位于包括存儲設(shè)備在內(nèi)的本地和遠程計算機存儲介質(zhì)中。
本說明書中的各個實施例均采用遞進的方式描述,各個實施例之間相同相似的部分互相參見即可,每個實施例重點說明的都是與其他實施例的不同之處。尤其,對于裝置實施例而言,由于其基本相似于方法實施例,所以描述得比較簡單,相關(guān)之處參見方法實施例的部分說明即可。以上所描述的裝置實施例僅僅是示意性的,在一些實施方式中所述作為分離部件說明的單元可以是或者也可以不是物理上分開的,作為單元顯示的部件可以是或者也可以不是物理單元,即可以位于一個地方,或者也可以分布到多個網(wǎng)絡(luò)單元上??梢愿鶕?jù)實際的需要選擇在一些實施方式中的部分或者全部模塊來實現(xiàn)本實施例方案的目的。本領(lǐng)域普通技術(shù)人員在不付出創(chuàng)造性勞動的情況下,即可以理解并實施。以上所述僅是本申請的具體實施方式,應(yīng)當指出,對于本技術(shù)領(lǐng)域的普通技術(shù)人員來說,在不脫離本申請原理的前提下,還可以做出若干改進和潤飾,這些改進和潤飾也應(yīng)視為本申請的保護范圍。