專利名稱:通過隱式應用模型來標識應用資源的制作方法
技術(shù)領(lǐng)域:
本發(fā)明涉及一種在計算環(huán)境中實施的方法,更具體地,涉及通過隱式應用模型來標識應用資源。
背景技術(shù):
計算機和計算系統(tǒng)已經(jīng)影響了現(xiàn)代生活的幾乎每個方面。計算機通常在工作、休閑、保健、運輸、娛樂、家政管理等中都有涉獵。計算機應用由眾多獨立的組件(例如,文件、注冊表鍵、服務、網(wǎng)站、用戶等)組成,這些組件被遍布放置在系統(tǒng)中,但不帶有各獨立部分之間的清楚的鏈接。各獨立部分之間的斷開使得諸如標識應用資產(chǎn)、備份、修復以及應用移除之類的動作變得復雜。在此要求保護的主題不限于解決任何缺點或僅在諸如上述環(huán)境中操作的各個實施例。相反,提供該背景僅用以示出在其中可實踐在此描述的部分實施例的一個示例性技術(shù)領(lǐng)域。
發(fā)明內(nèi)容
此處示出的一個實施例涉及一種在計算環(huán)境中實施的方法。方法包括用于確定離散應用邊界的動作。方法包括標識應用的一個或多個最初組件。方法還包括標識所述應用的一個或多個最初組件的靜態(tài)相關(guān)的組件。方法還包括標識所述應用的一個或多個最初組件的動態(tài)相關(guān)的組件。標識靜態(tài)相關(guān)組件和標識動態(tài)相關(guān)組件被迭代執(zhí)行。方法還包括基于靜態(tài)相關(guān)組件和動態(tài)相關(guān)組件來標識應用的離散邊界。提供本發(fā)明內(nèi)容以便以簡化形式介紹將在以下具體實施方式
中進一步描述的一些概念。本發(fā)明內(nèi)容既不旨在標識要求保護的主題的關(guān)鍵特征或必要特征,也不旨在用于幫助確定要求保護的主題的范圍。另外的特征和優(yōu)點將在以下的描述中闡述,并且部分可從該描述中顯而易見,或者可以從此處的教示實踐中習得。本發(fā)明的特征和優(yōu)點可以通過在所附權(quán)利要求中特別指出的手段和組合來實現(xiàn)并獲取。本發(fā)明的特征將從以下描述和所附權(quán)利要求書中變得完全顯而易見,或者可通過如下所述對本發(fā)明的實踐而獲知。
為了描述可獲得本主題的上述和其它優(yōu)點和特征的方式,將通過參考附圖中示出的本主題的具體實施例來呈現(xiàn)以上簡要描述的本主題的更具體描述。應該理解,這些附圖僅描繪了各典型實施例,因此其不應被認為是對范圍的限制,各實施例將通過使用附圖用附加特征和細節(jié)來描述并解釋,在附圖中圖1示出確定系統(tǒng)資源的示例;以及圖2示出確定離散應用邊界的方法。
具體實施例方式各實施例可包括構(gòu)建隱式的應用模型來標識應用的資源的功能。各實施例可包括使用ー組獨立或以各種組合形式使用的試探來標識與任意軟件應用相關(guān)聯(lián)的資產(chǎn)。各種可用的發(fā)現(xiàn)機制可被一起用來構(gòu)建應用模型。應用模型可被用于各種目的,包括但不限于將工作中的應用安裝移動到另一機器、驗證應用的安裝、創(chuàng)建應用的可重分發(fā)包、修復不工作的或損壞的應用安裝等等。為了構(gòu)建應用模型,各實施例可實現(xiàn)標識過程,過程包括(在一些示例實施例中)可被分解成三個類別的試探,三個類別是靜態(tài)發(fā)現(xiàn)試探、動態(tài)發(fā)現(xiàn)試探以及選擇細化試探。靜態(tài)方法包括檢查系統(tǒng)上的人工產(chǎn)品以確定屬于給定應用的系統(tǒng)內(nèi)容的子集。動態(tài)方法包括監(jiān)視應用使用以確定應用訪問哪些資源。細化方法被用于改進應用模型的精確度。這些試探通過移除其它標識技術(shù)檢測到的假陽性以及用與被發(fā)現(xiàn)的內(nèi)容有關(guān)的額外資源來擴充應用模型以改進應用模型的準確性。
靜態(tài)和動態(tài)技術(shù)關(guān)注于向系統(tǒng)提供有趣的內(nèi)容。這些技術(shù)用作為應用模型發(fā)現(xiàn)過程的入口點。細化技術(shù)進ー步處理由靜態(tài)和動態(tài)發(fā)現(xiàn)標識的信息。盡管細化技術(shù)中的許多都采用靜態(tài)分析,但由于它們的迭代性質(zhì),與靜態(tài)發(fā)現(xiàn)部分分開地調(diào)用它們?,F(xiàn)在參考圖1,示出了ー個示例。圖1示出應用102。靜態(tài)發(fā)現(xiàn)可被用于表征應用102的ー些部分。例如,靜態(tài)發(fā)現(xiàn)的使用使得包括靜態(tài)標識模塊的應用模型生成器104能夠查找應用資源,而無需真正地運行應用102。這包括查看諸如例如安裝器或卸載數(shù)據(jù)之類的イ目息以標識遍布在系統(tǒng)中的資源。例如,一個實施方式可使用MSI Windows Installer(由華盛頓州雷蒙德市的微軟公司提供)的卸載信息來定位資源。在一些實施例中,靜態(tài)發(fā)現(xiàn)可額外地或替換地包括處理應用文件內(nèi)容以及配置設(shè)置(諸如基于Windows 的應用的注冊■表內(nèi)容)來定位資源。例如,文件可在XML或其它配置文檔中被引用。動態(tài)發(fā)現(xiàn)可被用于表征應用102的ー些部分。為了更好地理解應用102,實施例可將監(jiān)視層106注入到應用102中,監(jiān)視層106有效地截取并解釋資源請求。在一些實施例中,這ー監(jiān)視層可被實現(xiàn)為DLL,其掛鉤系統(tǒng)API的一個子集以截取文件請求和/或配置請求(諸如基于Windows 的應用中的注冊表請求)。監(jiān)視層106可利用應用102本身的動作來構(gòu)建對應用102用來操作的資源的準確描述。這一信息可被提供給應用模型生成器104。各實施例可被實現(xiàn)成使用監(jiān)視層106來監(jiān)視以下動作中的ー個或多個文件訪問;配置訪問;C0M對象實例化;規(guī)范使用;細化等等。對于配置訪問,一些實施例可被實現(xiàn)在Wmdows 環(huán)境中,使得配置訪問可包括對注冊表條目的訪問。對于規(guī)范使用,一些實施例可使用 WMI (Windows Management Instrumentation, Windows 管理規(guī)范)。一些實施例可為應用模型細化使用兩種高級技術(shù)即黑名單110以及隱含包含的使用中的ー個或多個。黑名單110提供用于從應用模型中移除實際上不是應用的一部分的內(nèi)容。通常,這一列表包含屬于共享的基礎(chǔ)系統(tǒng)的一部分的內(nèi)容,諸如共享的庫或配置條目(諸如在實施基于微軟的系統(tǒng)的應用中的共享的DLL或注冊■表條目),但它可包括任何內(nèi)容。這ー過濾器的使用可被用在流水化化應用模型的內(nèi)容中以僅包括真正屬于應用的一部分的信息。存在眾多其中可以實施黑名單110的方式。一些實施例使用主動運行的系統(tǒng)來生成這一列表。另有一些實施例可使用現(xiàn)有應用模型來填充黑名單。例如,現(xiàn)有模型可具有與其相關(guān)聯(lián)的黑名單用于標識系統(tǒng)資源(與應用資源相對)。這一現(xiàn)有黑名單可被用來填充其它黑名單。作為補充或替代,可使用其它數(shù)據(jù)源。一些可能的替代包括休眠圖像(例如,虛擬硬盤)、數(shù)據(jù)庫、基于文本的表示和/或用戶提供的信息。隱含包括技術(shù)通過尋找與已經(jīng)被發(fā)現(xiàn)的內(nèi)容相關(guān)的內(nèi)容來對應用模型進行補充??杀粚嵤┑囊恍┦纠ɑ趹妙愋偷臉俗R的對服務器或服務元數(shù)據(jù)的標識;基于文件包括的對服務、網(wǎng)站以及COM對象的標識;基于文件ACL(訪問控制列表)信息的對本地用戶/組的標識;基于本地組成員關(guān)系的對本地用戶的標識等等。在一個特定實施例中,網(wǎng)站數(shù)據(jù)(即構(gòu)成網(wǎng)站內(nèi)容的文件)可通過標識來自由華盛頓州雷蒙德市的微軟公司提供的HS服務器(因特網(wǎng)信息服務)的元數(shù)據(jù)來標識。細化技術(shù)可被迭代地應用。例如,對文件的標識可導致對本地組的添加,這又可進一步導致對本地用戶的標識。在這種情況下,通過迭代應用,挑選單個文件將該文件、本地組以及本地用戶添加到應用模型中一些實施例可使用范圍調(diào)整機制來執(zhí)行細化。范圍擴展可擴展特定模型條目的范圍以覆蓋更大的數(shù)據(jù)集。說明性地,如果一個實施例確定單個文件是應用的足跡的一部分,則該實施例可調(diào)整范圍以表明與該文件處于相同目錄中的所有文件都應當是足跡的一部分。例如,如果發(fā)現(xiàn)c: \program files\my app\foo. exe是應用的一部分,貝U可以假設(shè)像c:\program files\my app\bar.1ni之類的其它內(nèi)容也都是應用的一部分,因為它們位于相同的目錄中。此外,各實施例可查看所選擇的項目的路徑(諸如文件路徑,或在微軟公司提供的各種技術(shù)中的注冊表路徑)并且確定在碰到不應當位于模型中的資源之前其父層實施例可向上經(jīng)過多遠。例如,如果 c: \programf iles\application\subdir\service. exe 位于應用模型中。各實施例可采用這一路徑并開始向回走以確定c:\program files\application\subdir是否應當在模型內(nèi),然后是c:\program f iles\application,再然后是c:\programfiles??梢灾纁: \program files不應當在模型內(nèi),因為它目前在黑名單中。各實施例可因此調(diào)整service, exe的初始條目的范圍以覆蓋c:\program files\application中的全部內(nèi)容,該目錄是假設(shè)應當在模型內(nèi)的最后一個目錄。在另一范圍調(diào)整示例中,如果實施例確定信息服務應用池是應用的足跡的一部分,則各實施例可確定屬于池的一部分的任何信息服務網(wǎng)站也都是應用的一部分。作為替換或補充,一些實施例可使用依賴性走查來執(zhí)行細化。以下示例示出一個示例實施例。該示例追蹤由于包括單個文件而引起的對應用模型的影響。這一示例開始于靜態(tài)分析標識用于包括在應用模型中的文件(在這一示例中,是“default, aspx”)。當文件被添加到模型中時,隱式的包括試探被執(zhí)行并用于將該文件標識為屬于web應用。知道該文件屬于web應用之后,標識可包括更多關(guān)于該應用的附加數(shù)據(jù)存儲,在這一示例中,該附加數(shù)據(jù)存儲是信息服務器,在示出的示例中,該信息服務器是華盛頓州雷蒙德市的微軟公司提供的HS。各實施例可通過IIS搜索引用該文件的網(wǎng)站,并在應用模型中包括關(guān)于所標識的網(wǎng)站的信息以及與該網(wǎng)站相關(guān)聯(lián)的其它文件。網(wǎng)站元數(shù)據(jù)和文件的包括觸發(fā)對網(wǎng)站本身以及已被帶入到應用模型中的新文件的隱式包括試探。關(guān)注于網(wǎng)站本身,各實施例可確定網(wǎng)站的應用池在特定本地用戶帳戶下執(zhí)行。各實施例可隨后將該用戶帳戶添加到應用模型。在這ー過程的末尾,各實施例將基于單個文件的發(fā)現(xiàn)標識出多個應用資產(chǎn)(例如,文件、Iis元數(shù)據(jù)以及本地用戶)。各實施例可實施利用用于構(gòu)建應用模型的集中過程的集中模型構(gòu)建。這ー過程可接收來自多個源的輸入并將這ー輸入聚集到單個綜合應用模型中。這ー方法在一些實施例中是有用的,因為現(xiàn)代軟件應用包括多個過程,并且依賴于來自該應用的單個方面的輸入可能不能提供與查看應用整體相同的畫面。盡管ー些實施例使用這ー集中過程來構(gòu)建更全面的模型,但所描述的技術(shù)不限于這ー集中過程。以下討論現(xiàn)涉及可以執(zhí)行的多種方法以及方法動作。雖然用特定次序討論或用以特定次序發(fā)生的流程圖示出了各個方法動作,但除非明確規(guī)定否則不需要特定次序,或因為ー動作依賴于另一動作在執(zhí)行該動作之前完成而需要特定次序?,F(xiàn)在參考圖2,示出了方法200??梢栽谟嬎悱h(huán)境中實施方法200。方法200包括用于確定離散應用邊界的動作。方法200包括標識應用的ー個或多個最初組件(動作202)。例如,如以上所說明的,與應用相關(guān)聯(lián)的文件(諸如以上示出的“default, aspx”)可被標識。這可以是用于定義應用邊界的最初開始。方法200還包括標識所述應用的ー個或多個最初組件的靜態(tài)相關(guān)的組件(動作204)。例如,可執(zhí)行靜態(tài)分析來靜態(tài)標識什么組件與最初標識的組件相關(guān)。上文以及以下示出的示例中討論了各種靜態(tài)分析技木。值得注意的是,標識靜態(tài)相關(guān)組件可通過標識與最初組件直接靜態(tài)相關(guān)的靜態(tài)相關(guān)組件或者通過標識與在執(zhí)行靜態(tài)和/或動態(tài)分析時發(fā)現(xiàn)的組件靜態(tài)相關(guān)的靜態(tài)相關(guān)組件來完成。方法200還包括標識所述應用的ー個或多個最初組件的動態(tài)相關(guān)的組件(動作206)??蓤?zhí)行方法200,其中標識動態(tài)相關(guān)組件包括在運行時監(jiān)視被標識的應用組件的資源訪問。圖1示出可被用于標識動態(tài)相關(guān)組件的監(jiān)視層106。具體來說,如以上所示的,監(jiān)視層可發(fā)現(xiàn)應用執(zhí)行的動態(tài)調(diào)用以幫助標識應用的各部分。值得注意的是,標識動態(tài)相關(guān)組件可通過標識與最初組件直接動態(tài)相關(guān)的動態(tài)相關(guān)組件或者通過標識與在執(zhí)行靜態(tài)和/或動態(tài)分析時發(fā)現(xiàn)的組件動態(tài)相關(guān)的動態(tài)相關(guān)組件來完成。標識靜態(tài)相關(guān)組件(動作204)和標識動態(tài)相關(guān)組件(動作206)可迭代執(zhí)行。例如,可對由步驟204和206發(fā)現(xiàn)的與最初組件相關(guān)的組件進行分析以發(fā)現(xiàn)與相關(guān)組件相關(guān)的組件。如前面所提到的,迭代地執(zhí)行靜態(tài)和動態(tài)標識可包括采用一遍靜態(tài)或動態(tài)標識的結(jié)果并將同樣的試探應用于該結(jié)果,從而生成更大的將被包括的組件集合。方法200還包括基于靜態(tài)相關(guān)組件和動態(tài)相關(guān)組件來標識應用的離散邊界(動作208)。具體來說,通過方法200的各動作標識的組件(包括最初組件)可被用于離散地標識特定應用的邊界。例如,在一些實施例中,離散邊界定義了應用的功能性實例所需的組件。例如,如果被標識的組件全部都被傳輸?shù)奖慌渲贸芍骺卦搼玫囊徊煌瑱C器或設(shè)備,可使該應用工作而無需添加附加應用組件。方法200還可包括基于離散邊界創(chuàng)建可再分發(fā)的包。例如,被標識的組件可被打包成可再分發(fā)的包??稍俜职l(fā)的包可被用于部署或修復應用。例如,可再分發(fā)的包可被放置在安裝介質(zhì)上并被用于安裝應用。作為替換,可再分發(fā)的包可由系統(tǒng)用于標識缺失的、損壞的、或過時的應用部件,并且隨后使用可再分發(fā)的包來替換損壞的或缺失的應用部件或者提供缺失的應用部件。
方法200還可包括基于離散邊界內(nèi)的組件對應用的正確性或完整性中的至少一個進行驗證。例如,可以知道什么組件應當對于給定應用可用。將基于分析什么組件實際可用與什么組件應當可用進行比較來幫助確定組件是否缺失、損壞、過期等。在一些實施例中,這可通過標識應用的另一已知正工作的安裝的第二離散邊界來實現(xiàn)。可對應用的兩個不同安裝進行比較。此外,第二離散邊界中標識的組件可被用于修復第一離散邊界中的缺失、損壞或過時的組件??蓤?zhí)行方法200,其中標識靜態(tài)相關(guān)組件包括檢查公知的擴展點。這樣的擴展點可以是操作系統(tǒng)、服務器注冊(諸如IIS服務器注冊)或?qū)ο笞?諸如COM注冊)的擴展點。方法200還可包括將標識的組件放入黑名單以從應用邊界中排除組件。例如,如圖1中所示,黑名單110可被創(chuàng)建以移除靜態(tài)和動態(tài)分析期間發(fā)現(xiàn)的、但已知不是應用本身的一部分的組件。例如,應用所使用的操作系統(tǒng)組件可被標識在黑名單中以防止它們被包括在應用邊界中。可執(zhí)行方法200,其中標識應用的一個或多個最初組件包括接收用戶輸入。具體來說,用戶可指定已知是應用的一部分的組件。被指定的組件可隨后被用于標識應用的其它組件。作為替換或補充,各實施例可使用諸如MSI數(shù)據(jù)之類的安裝器日志來標識應用的組件。在又一作為替換或補充的實施例中,可使用白名單來標識應用的組件。這樣的被標識的組件可隨后被用來尋找其它組件??蓤?zhí)行方法200,其中標識離散組件包括接收用戶輸入。例如,用戶可指定屬于應用的應用的特定部分。這一用戶輸入可被簡單地添加到離散邊界,或被用于使用以上概括的各種方式尋找應用的附加部分。此外,各種方法可由包括一個或多個處理器和諸如計算機存儲器等計算機可讀介質(zhì)的計算機系統(tǒng)來實施。具體而言,計算機存儲器可存儲計算機可執(zhí)行指令,這些指令在由一個或多個處理器執(zhí)行時使得諸如各實施例中所述的各個動作等各種功能被執(zhí)行。本發(fā)明的各實施例可以包括或利用包含計算機硬件的專用或通用計算機,這將在下文中更詳細地討論。本發(fā)明范圍內(nèi)的各個實施例還包括用于承載或存儲計算機可執(zhí)行指令和/或數(shù)據(jù)結(jié)構(gòu)的物理以及其他計算機可讀介質(zhì)。這種計算機可讀介質(zhì)可以是可由通用或?qū)S糜嬎銠C系統(tǒng)訪問的任何可用介質(zhì)。存儲計算機可執(zhí)行指令的計算機可讀介質(zhì)是物理存儲介質(zhì)。承載計算機可執(zhí)行指令的計算機可讀介質(zhì)是傳輸介質(zhì)。由此,作為示例而非限制,本發(fā)明的各個實施例可包括至少兩種明顯不同的計算機可讀介質(zhì)物理計算機可讀存儲介質(zhì)和傳輸計算機可讀介質(zhì)。物理計算機存儲介質(zhì)包括RAM、ROM、EEPROM、CD-ROM或其他光盤存儲(如CD、DVD
等)、磁盤存儲或其他磁存儲設(shè)備、或可用于存儲計算機可執(zhí)行指令或數(shù)據(jù)結(jié)構(gòu)形式的所需程序代碼裝置且可由通用或?qū)S糜嬎銠C訪問的任何其他介質(zhì)?!熬W(wǎng)絡(luò)”被定義為允許在計算機系統(tǒng)和/或模塊和/或其他電子設(shè)備之間傳送電子數(shù)據(jù)的一個或多個數(shù)據(jù)鏈路。當信息通過網(wǎng)絡(luò)或另一個通信連接(硬連線、無線、或者硬連線或無線的組合)傳輸或提供給計算機時,該計算機將該連接適當?shù)匾暈閭鬏斀橘|(zhì)。傳輸介質(zhì)可包括可用于承載計算機可執(zhí)行指令或數(shù)據(jù)結(jié)構(gòu)形式的期望程序代碼裝置且可由通用或?qū)S糜嬎銠C訪問的網(wǎng)絡(luò)和/或數(shù)據(jù)鏈路。以上介質(zhì)的組合也被包括在計算機可讀介質(zhì)的范圍內(nèi)。
此外,在到達各種計算機系統(tǒng)組件之后,計算機可執(zhí)行指令或數(shù)據(jù)結(jié)構(gòu)形式的程序代碼裝置可從傳輸計算機可讀介質(zhì)自動轉(zhuǎn)移到物理計算機可讀存儲介質(zhì)(或者相反)。例如,通過網(wǎng)絡(luò)或數(shù)據(jù)鏈路接收到的計算機可執(zhí)行指令或數(shù)據(jù)結(jié)構(gòu)可被緩存在網(wǎng)絡(luò)接ロ模塊(例如,“NIC”)內(nèi)的RAM中,然后最終被傳送到計算機系統(tǒng)RAM和/或計算機系統(tǒng)處的較不易失性的計算機可讀物理存儲介質(zhì)。因此,計算機可讀物理存儲介質(zhì)可被包括在同樣(或甚至主要)利用傳輸介質(zhì)的計算機系統(tǒng)組件中。計算機可執(zhí)行指令包括,例如使通用計算機、專用計算機、或?qū)S锰幚碓O(shè)備執(zhí)行某一功能或某組功能的指令和數(shù)據(jù)。計算機可執(zhí)行指令可以是例如ニ進制代碼、諸如匯編語言之類的中間格式指令、或者甚至源代碼。雖然用結(jié)構(gòu)特征和/或方法動作專用的語言描述了本主題,但是應當理解,所附權(quán)利要求書中定義的主題不必限于以上所述的特征或動作。相反,所述的特征和動作是作為實現(xiàn)權(quán)利要求的示例形式而公開的。本領(lǐng)域的技術(shù)人員將理解,本發(fā)明可以在具有許多類型的計算機系統(tǒng)配置的網(wǎng)絡(luò)計算環(huán)境中實踐,這些計算機系統(tǒng)配置包括個人計算機、臺式計算機、膝上型計算機、消息處理器、手持式設(shè)備、多處理器系統(tǒng)、基于微處理器的或可編程消費電子設(shè)備、網(wǎng)絡(luò)PC、小型計算機、大型計算機、移動電話、PDA、尋呼機、路由器、交換機等等。本發(fā)明也可在其中通過網(wǎng)絡(luò)(通過硬連線數(shù)據(jù)鏈路、無線數(shù)據(jù)鏈路,或者通過硬連線和無線數(shù)據(jù)鏈路的組合)鏈接的本地和遠程計算機系統(tǒng)兩者都執(zhí)行任務的分布式系統(tǒng)環(huán)境中實踐。在分布式系統(tǒng)環(huán)境中,程序模塊可位于本地和遠程存儲器存儲設(shè)備兩者中。本發(fā)明可具體化為其他具體形式而不背離其精神或特征。所述實施例在所有方面都應被認為只是說明性而非限制性的。因此,本發(fā)明的范圍由所附權(quán)利要求書而非以上描述指示。落入權(quán)利要求書的等效方案的含義和范圍內(nèi)的所有改變都涵蓋在權(quán)利要求書的范圍內(nèi)。
權(quán)利要求
1.一種在計算環(huán)境中的用于確定離散應用(102)邊界的方法(200),所述方法(200)包括標識應用(102)的一個或多個最初組件(202);標識與所述應用(102)的一個或多個最初組件靜態(tài)相關(guān)的組件(204);標識與所述應用(102)的一個或多個最初組件動態(tài)相關(guān)的組件(206);其中,標識靜態(tài)相關(guān)組件和標識動態(tài)相關(guān)組件被迭代執(zhí)行;以及基于所述一個或多個最初組件、所述靜態(tài)相關(guān)組件以及所述動態(tài)相關(guān)組件來標識所述應用(102)的離散邊界。
2.如權(quán)利要求1所述的方法,其特征在于,所述離散邊界定義應用的功能性實例所需的組件。
3.如權(quán)利要求1所述的方法,其特征在于,還包括基于所述離散邊界創(chuàng)建可再分發(fā)的包。
4.如權(quán)利要求1所述的方法,其特征在于,還包括基于所述離散邊界內(nèi)的組件對應用的正確性或完整性中的至少一個進行驗證。
5.如權(quán)利要求1所述的方法,其特征在于,標識靜態(tài)相關(guān)組件包括檢查操作系統(tǒng)或操作系統(tǒng)的組件的公知擴展點。
6.如權(quán)利要求1所述的方法,其特征在于,標識靜態(tài)相關(guān)組件包括檢查資源間的公知關(guān)系。
7.如權(quán)利要求1所述的方法,其特征在于,標識動態(tài)相關(guān)組件包括在運行時監(jiān)視被標識的應用組件的資源訪問。
8.如權(quán)利要求1所述的方法,其特征在于,還包括將標識的組件放入黑名單以從應用邊界中排除組件。
9.如權(quán)利要求1所述的方法,其特征在于,標識應用的一個或多個最初組件包括接收用戶輸入。
10.如權(quán)利要求1所述的方法,其特征在于,標識離散組件包括接收用戶輸入。
全文摘要
本發(fā)明涉及通過隱式應用模型來標識應用資源。確定離散應用邊界。方法包括標識應用的一個或多個最初的組件。方法還包括標識所述應用的一個或多個最初組件的靜態(tài)和/或動態(tài)相關(guān)的組件。標識靜態(tài)相關(guān)組件和標識動態(tài)相關(guān)組件被反復執(zhí)行。方法還包括基于靜態(tài)相關(guān)組件和動態(tài)相關(guān)組件來標識應用的離散邊界。
文檔編號G06F9/44GK103019717SQ20121054459
公開日2013年4月3日 申請日期2012年12月14日 優(yōu)先權(quán)日2011年12月15日
發(fā)明者J·東克爾, E·杰瓦特, D·T·伊索卡 申請人:微軟公司