欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

一種分布式服務(wù)系統(tǒng)的服務(wù)提供方法

文檔序號:6636104閱讀:153來源:國知局

專利名稱::一種分布式服務(wù)系統(tǒng)的服務(wù)提供方法
技術(shù)領(lǐng)域
:本發(fā)明涉及一種計算機數(shù)據(jù)服務(wù)提供方法,尤其涉及一種用于分布式服務(wù)系統(tǒng)的服務(wù)提供方法。
背景技術(shù)
:分布式服務(wù)系統(tǒng)就是將服務(wù)系統(tǒng)的功能拆分,將各個功能放在幾個獨立的組件上,通過這幾個組件之間的相互協(xié)作,來完成整個系統(tǒng)的功能。在這里,幾個獨立的組件可以是指幾個獨立的CPU,但更通常的是指網(wǎng)絡(luò)上的幾臺計算機。采用分布式系統(tǒng),最大的優(yōu)點表現(xiàn)在系統(tǒng)的處理速度上。系統(tǒng)的各個功能放在幾個獨立的組件上,各部分的組件完成自己的功能塊,以并行的方式協(xié)同工作。分布式服務(wù)系統(tǒng)另外的優(yōu)點還在于個功能模塊分開,便于管理、維護和更新,服務(wù)器的管理維護在大型的服務(wù)系統(tǒng)中也是相當重要的。一個典型的分布式服務(wù)系統(tǒng)大致包括以下幾部分表示層,主要負責(zé)業(yè)務(wù)層與用戶之間的交流接口和數(shù)據(jù)傳遞工作,是唯一一個直接與用戶打交道的部分;業(yè)務(wù)層,是分布式服務(wù)系統(tǒng)的心臟,最主要的數(shù)據(jù)處理工作和服務(wù)就由這一部分完成和提供;數(shù)據(jù)源,主要用于存儲數(shù)據(jù)。然而,和運行在一臺機器中的服務(wù)提供者和使用者相比,分布式系統(tǒng)在服務(wù)提供方面具有大得多的復(fù)雜性。造成這種復(fù)雜性的原因主要有以下幾個方面1、由于系統(tǒng)分布,服務(wù)器程序和客戶程序很可能不是由同一個開發(fā)團隊開發(fā),這就造成服務(wù)提供者和客戶之間的接口不規(guī)范,導(dǎo)致互操作困難,當涉及多個服務(wù)提供者和客戶時,情況就會變得更加糟糕。2、正是由于上面所述的不規(guī)范性,造成服務(wù)的擴展困難。當由于需求的變化需要增加新的服務(wù)或者對現(xiàn)有服務(wù)進行更改時,就會造成嚴重的連鎖反應(yīng)那些和改動無關(guān)的客戶(或者服務(wù)器)也不得不進行重新的構(gòu)建和部署。當系統(tǒng)涉及隸屬于多個不同公司的開發(fā)團隊時,這種連鎖反應(yīng)會造成巨大的不必要的浪費。3、部署是分布式服務(wù)中的一項重要工作,這項工作的難度直接影響到分布式服務(wù)發(fā)布和升級的工作量。遺憾的是,現(xiàn)在有很多服務(wù)提供者在需要升級或者提供新的服務(wù)時,都不得不重新構(gòu)建并重啟整個系統(tǒng),這不僅嚴重影響了服務(wù)的可用性,并且也給升級工作帶來了很大的工作量。正是由于上面的這些原因,使得當前很多分布式系統(tǒng)在服務(wù)提供方面非常的不一致、難以擴展和部署。而開發(fā)這些系統(tǒng)的公司和團體也不得不耗費大量的不必要的資金和精力。
發(fā)明內(nèi)容本發(fā)明所要解決的技術(shù)問題在于提供一種分布式服務(wù)系統(tǒng)的服務(wù)提供方法,克服現(xiàn)有技術(shù)中存在的訪問不一致,難于擴展,以及由于服務(wù)的添加或者更改造成的巨大連鎖反應(yīng)等問題。本發(fā)明提供一種分布式服務(wù)系統(tǒng)的服務(wù)提供方法,包括如下步驟確定要使用的擴展接口、公共管理服務(wù)以及要提供的具體服務(wù);由所述具體服務(wù)實現(xiàn)所述擴展接口,并確定各服務(wù)的名稱與服務(wù)主實現(xiàn);根據(jù)所述各服務(wù)的名稱與服務(wù)主實現(xiàn),分別生成描述各服務(wù)的配置文件;系統(tǒng)通過讀取并解析所述配置文件,分別加載各服務(wù)的主實現(xiàn);發(fā)布所述公共管理服務(wù),并將要提供的具體服務(wù)在公共管理服務(wù)上進行注冊發(fā)布。優(yōu)選的,本發(fā)明進一步包括如下步驟公共管理服務(wù)根據(jù)用戶指示確定用戶需要獲取的具體服務(wù)名稱;公共管理服務(wù)根據(jù)具體服務(wù)名稱獲取該具體服務(wù)實體提供給用戶使用。其中,所述通過擴展接口實現(xiàn)服務(wù),并確定服務(wù)名稱與服務(wù)主實現(xiàn)步驟,進一步包括確定該服務(wù)的實現(xiàn)策略的步驟,包括如下步驟判斷并確定該服務(wù)需要分解為不同的實現(xiàn)策略;分解問題領(lǐng)域,解析出需要實現(xiàn)的策略組件;確定策略與服務(wù)之間的協(xié)作方式;實現(xiàn)出與服務(wù)相協(xié)作的策略組件。其中,所述生成描述各服務(wù)的配置文件步驟,所述配置文件進一步包括信息組成服務(wù)的策略名稱、策略實現(xiàn)組件,以及策略在服務(wù)實現(xiàn)中的組合方式。其中,所述加載步驟,進一步包括如下步驟判斷并確定所述配置文件中含有策略配置信息;解析出配置文件中的策略實現(xiàn)及其組合方式,并對其進行加載;根據(jù)策略的組合方式,將策略實現(xiàn)組合如服務(wù)主實現(xiàn)中。采用本發(fā)明所述方法,與現(xiàn)有技術(shù)相比,提供了一種高效,便捷,一致,并且易于擴展的分布式服務(wù)提供方法,采用配置文件的方式方便對服務(wù)的組織,服務(wù)的配置發(fā)布不再采用硬編碼的方式,而是采用動態(tài)加載和控制反轉(zhuǎn)(InversionofControl)技術(shù)使得服務(wù)的表示和實現(xiàn)分離,從而可以很方便地實現(xiàn)服務(wù)的多樣性。運用這種方法,可以極大地節(jié)省服務(wù)開發(fā)的時間,可以幫助分布式服務(wù)系統(tǒng)構(gòu)建底層服務(wù)管理框架。由于控制反轉(zhuǎn)的引入,應(yīng)用對框架不存在直接依賴,提高了服務(wù)組件的可測試性,本發(fā)明提供的配置文件組織方式和服務(wù)訪問方式還可以根據(jù)實際需要去進行擴展,應(yīng)用范圍更廣,實現(xiàn)了服務(wù)的可擴展性,訪問的一致性,服務(wù)實現(xiàn)的多樣性,不同類型服務(wù)的易配置和易添加性以及動態(tài)加載性。本發(fā)明可以提供高度模塊化且可動態(tài)、增量擴展的服務(wù),特別適合于電信設(shè)備管理中EMS(網(wǎng)元管理系統(tǒng))和NMS(網(wǎng)絡(luò)管理系統(tǒng))之間的服務(wù)提供方式。圖1為本發(fā)明所述的分布式服務(wù)系統(tǒng)的服務(wù)提供方法流程示意圖;圖2為本發(fā)明所述的服務(wù)實現(xiàn)及配置文件生成過程示意圖;圖3為本發(fā)明所述的服務(wù)加載與發(fā)布流程示意圖;圖4為為本發(fā)明所述的用戶使用服務(wù)時的流程示意圖。具體實施例方式如圖1所示,為本發(fā)明所述的分布式服務(wù)提供方法流程示意圖。首先,確定要使用的擴展接口、公共管理服務(wù)以及要提供的具體服務(wù)(步驟101);由所述具體服務(wù)實現(xiàn)所述擴展接口,并確定各服務(wù)的名稱與服務(wù)主實現(xiàn)(步驟102);根據(jù)所述各服務(wù)的名稱與服務(wù)主實現(xiàn),分別生成描述各服務(wù)的配置文件(步驟103);系統(tǒng)通過讀取并解析所述配置文件,分別加載各服務(wù)的主實現(xiàn)(步驟104);發(fā)布所述公共管理服務(wù),并將要提供的具體服務(wù)在公共管理服務(wù)上進行注冊發(fā)布(步驟105)。此外,如果具體服務(wù)還需要不同的實現(xiàn)策略,那么,本發(fā)明還可以進而將不同的策略及其組合方式進一步的描述入配置文件,并在服務(wù)加載時,通過讀取和解析配置文件,動態(tài)的將不同策略組合入服務(wù)主實現(xiàn)中。本發(fā)明所使用的擴展接口,是一種運用在框架中的常用技術(shù)。該技術(shù)可以使得接口的功能變得可擴展而不會影響到已有的使用者。為了達到這個目的,擴展接口技術(shù)提供了一個高層的、一致的抽象服務(wù)接口,該接口中定義了用于服務(wù)擴展所需要的方法,比如服務(wù)查詢等,由具體的服務(wù)實現(xiàn)該接口。本發(fā)明所述的具體服務(wù),其在實現(xiàn)時必須要繼承上述確定好的擴展接口。其中,公共管理服務(wù)為系統(tǒng)的一項基本服務(wù),在啟動時加載和發(fā)布,所有其他服務(wù)都通過向公共管理服務(wù)注冊的方式進行發(fā)布。本發(fā)明所述的描述服務(wù)的配置文件采用XML格式,其中的信息可以具體涉及服務(wù)名稱,服務(wù)實現(xiàn)主實現(xiàn)組件,組成服務(wù)的策略名稱和策略實現(xiàn)組件,以及策略在服務(wù)實現(xiàn)中的組合方式。使用服務(wù)描述的配置文件,系統(tǒng)可以在運行時動態(tài)地加載并根據(jù)策略名稱、組合方式等靈活地組裝服務(wù),從而可以在對系統(tǒng)其他部分沒有任何影響的情況下,擴展和改變服務(wù)的內(nèi)容。所述配置文件的描述格式舉例如下<servicereg><servicename="sample"imp="sampleServiceImp"><strategyname="strategyl"imp="strategylImp"means="setStrategyl"/><strategyname="strategy2"imp="strategy2Imp"means="setStrategy2"/></service></servicereg>優(yōu)選的,在生成配置文件后,可以把具體的服務(wù)、策略實現(xiàn)以及對應(yīng)的配置文件,復(fù)制到系統(tǒng)指定的目錄下,為服務(wù)的加載和啟動做準備。系統(tǒng)加載、啟動并發(fā)布服務(wù)時,系統(tǒng)在配置目錄讀取服務(wù)配置文件,采用動態(tài)加載和控制反轉(zhuǎn)(InversionOfControl)技術(shù)來完成服務(wù)的加載、組裝,并通過把服務(wù)注冊到公共管理服務(wù)的方式發(fā)布服務(wù)??刂品崔D(zhuǎn)是這樣一種技術(shù),它可以在運行時動態(tài)、靈活地建立起組件之間的依賴關(guān)系,而組件本身卻無需知曉和其建立起關(guān)系的其他組件的細節(jié)。這樣就可以使得組件的開發(fā)者集中精力于組件本身。當客戶使用服務(wù),客戶可以使用一個統(tǒng)一的訪問點去獲取公共的管理服務(wù)。通過該服務(wù),客戶可以通過服務(wù)名稱查詢自己感興趣的具體服務(wù),如果服務(wù)存在,就可以獲取并使用該服務(wù)了。如圖2所示,為本發(fā)明所述的服務(wù)實現(xiàn)及配置文件生成過程示意圖。首先,由具體的服務(wù)實現(xiàn)去擴展事先定義的擴展接口,也就是實現(xiàn)服務(wù)實現(xiàn),并確定出服務(wù)名稱(步驟201);然后,判斷服務(wù)是否需要分解為不同的實現(xiàn)策略(步驟202),若步驟202的判斷為假,跳至步驟206;若步驟202的判斷為真,則描述服務(wù)實現(xiàn)策略(步驟203),就是分解問題領(lǐng)域,解析出需要實現(xiàn)的策略組件;描述服務(wù)策略組合方式(步驟204),就是確定策略和服務(wù)之間的協(xié)作方式;實現(xiàn)服務(wù)實現(xiàn)策略(步驟205),就是實現(xiàn)出與服務(wù)協(xié)作的策略組件;生成用于服務(wù)描述的配置文件(步驟206),就是將上面分析的服務(wù)名稱,服務(wù)實現(xiàn)組件,組成服務(wù)的策略名稱和策略實現(xiàn)組件,以及策略在服務(wù)實現(xiàn)中的組合方式描述在在配置文件中。如圖3所示,為本發(fā)明所述的服務(wù)加載與發(fā)布流程示意圖。首先,觸發(fā)服務(wù)加載動作(步驟301);然后,讀取并解析服務(wù)配置文件(步驟302);加載服務(wù)主實現(xiàn),對從文件中解析出的服務(wù)主實現(xiàn)組件,動態(tài)加載(步驟303);判斷服務(wù)配置文件中是否有策略配置,就是看服務(wù)配置文件中是否有對服務(wù)主實現(xiàn)的策略組件配置(步驟304);如果步驟304判斷為假,則轉(zhuǎn)步驟307;如果步驟304判斷為真,則分析并加載策略實現(xiàn)(步驟305),就是解析出配置文件中的策略組合方式并動態(tài)加載策略實現(xiàn)組件;再把策略實現(xiàn)組合進服務(wù)實現(xiàn)主體(步驟306),根據(jù)步驟305解析出的策略組合方式,把策略實現(xiàn)組合進服務(wù)實現(xiàn)主體;最后把服務(wù)實現(xiàn)注冊到公共管理服務(wù)中(步驟307),公共管理服務(wù)在系統(tǒng)啟動時發(fā)布,所有的其他服務(wù)通過在公共管理服務(wù)上注冊的方式發(fā)布。如圖4所示,為本發(fā)明所述的用戶使用服務(wù)時的流程示意圖。首先,客戶獲取公共管理服務(wù)(步驟401);然后,客戶告知公共管理服務(wù)自己想獲取的具體服務(wù)名稱(步驟402);然后,客戶使用公共管理服務(wù)獲取具體服務(wù)實體(步驟403);最后,客戶使用具體服務(wù)(步驟404)。下面用JAVA語言實現(xiàn)的一個例子來說明本發(fā)明,該例子中采用CORBA作為分布式對象的基礎(chǔ)平臺。首先確定一個擴展接口,在本例中,這個擴展接口是一個退化接口interfaceCommService{};然后我們再確定一個公共管理服務(wù)對象interfaceServiceMng{CommServicegetService(instringservname);};然后再確定一個要實現(xiàn)的服務(wù),例子采用最簡單的HelloWorld樣例interfaceHelloworldService::CommService{voidsayHello();};上述過程可以采用IDL語言進行描述,IDL是用于CORBA協(xié)議的接口定義語言,與此相似的,如果采用其他的協(xié)議,可是使用其他的定義語言來完成定義。進一步,分析該服務(wù)實現(xiàn)中是否需要不同的實現(xiàn)策略,例如在本例的服務(wù)中,可以采用不同的語言策略。對中文來說,要說“世界,你好!”,對英文來說,要說“HelloWorld!”,所以,需要兩種不同的語言策略。下面是這兩種策略的具體實現(xiàn)。publicinterfaceHelloWorld{publicStringgetHello();}PublicclassEnglishHelloworldimplementsHelloWorld{publicStringgetHello(){return“HelloWorld!";}}publicclassChineseHelloWorldimplementsHelloWorld{publicStringgetHello(){return"世界,你好!";}}接著,實現(xiàn)服務(wù),在該服務(wù)實現(xiàn)中,確定了策略的組合方式。publicclassHelloworldServiceImplextendsHelloworldServicePOA{privateORBorb=null;privateHelloWorldhello;publicvoidsetORBEnv(ORBorb){this.orb=orb;}publicvoidsayHello(){System.out.println(hello.getHello());}PublicvoidsetHello(HelloWorldhelloworld){this.hello=helloworld;}}接下來,生成描述該服務(wù)的配置文件,對于英文來說如下<servicereg><servicename="HelloWorld"imp="HelloworldServiceImpl"><strategyname="language"imp="EnglishHelloworld"means="setHello"/></service></servicereg>對于中文來說如下<servicereg><servicename="HelloWorld"imp="HelloworldServiceImpl"><strategyname="language"imp="ChineseHelloWorld"means="setHello"/></service></servicereg>對于本例來說,公共管理服務(wù)的實現(xiàn)如下publicclassServiceMngImplextendsServiceMngPOA{publicCommServicegetService(Stringservname){returnservices.getservname);}publicvoidregisterService(Stringname,CommServicesrv){services_.put(name,srv);}privateHashtableservices_=newHashtable();}系統(tǒng)在加載HelloWorld服務(wù)時,會讀取并分析HelloWorld服務(wù)的配置文件。首先動態(tài)加載該服務(wù)的主實現(xiàn)HelloworldServiceImpl,然后分析并加載相應(yīng)的策略,并根據(jù)所配置的組合手段把策略組合進服務(wù)實現(xiàn)中,并通過調(diào)用公共管理服務(wù)ServiceMngImpl的registerService方法把自己發(fā)布出去??蛻粢L問HelloWorld服務(wù)時,首先獲得CORBA的命名服務(wù),然后獲得公共管理服務(wù)ServiceMngImpl,調(diào)用ServiceMngImpl的getService(“HelloWorld”)方法獲得HelloWorld服務(wù)。權(quán)利要求1.一種分布式服務(wù)系統(tǒng)的服務(wù)提供方法,其特征在于,包括如下步驟確定要使用的擴展接口、公共管理服務(wù)以及要提供的具體服務(wù);由所述具體服務(wù)實現(xiàn)所述擴展接口,并確定各服務(wù)的名稱與服務(wù)主實現(xiàn);根據(jù)所述各服務(wù)的名稱與服務(wù)主實現(xiàn),分別生成描述各服務(wù)的配置文件;系統(tǒng)通過讀取并解析所述配置文件,分別加載各服務(wù)的主實現(xiàn);發(fā)布所述公共管理服務(wù),并將要提供的具體服務(wù)在公共管理服務(wù)上進行注冊發(fā)布。2.如權(quán)利要求1所述的方法,其特征在于,進一步包括如下步驟公共管理服務(wù)根據(jù)用戶指示確定用戶需要獲取的具體服務(wù)名稱;公共管理服務(wù)根據(jù)具體服務(wù)名稱獲取該具體服務(wù)實體提供給用戶使用。3.如權(quán)利要求1所述的方法,其特征在于,所述通過擴展接口實現(xiàn)服務(wù),并確定服務(wù)名稱與服務(wù)主實現(xiàn)步驟,進一步包括確定該服務(wù)的實現(xiàn)策略的步驟,包括判斷并確定該服務(wù)需要分解為不同的實現(xiàn)策略;分解問題領(lǐng)域,解析出需要實現(xiàn)的策略組件;確定策略與服務(wù)之間的協(xié)作方式;實現(xiàn)出與服務(wù)相協(xié)作的策略組件。4.如權(quán)利要求3所述的方法,其特征在于,所述生成描述各服務(wù)的配置文件步驟,所述配置文件進一步包括信息組成服務(wù)的策略名稱、策略實現(xiàn)組件,以及策略在服務(wù)實現(xiàn)中的組合方式。5.如權(quán)利要求1所述的方法,其特征在于,所述生成描述各服務(wù)的配置文件步驟后,進一步包括步驟將具體的服務(wù)實現(xiàn)以及對應(yīng)的配置文件復(fù)制到系統(tǒng)指定的目錄下,為加載做準備。6.如權(quán)利要求4所述的方法,其特征在于,所述生成描述各服務(wù)的配置文件步驟后,進一步包括步驟將具體的服務(wù)、策略實現(xiàn)以及對應(yīng)的配置文件復(fù)制到系統(tǒng)指定的目錄下。7.如權(quán)利要求4所述的方法,其特征在于,所述加載步驟,進一步包括如下步驟判斷并確定所述配置文件中含有策略配置信息;解析出配置文件中的策略實現(xiàn)及其組合方式,并對其進行加載;根據(jù)策略的組合方式,將策略實現(xiàn)組合如服務(wù)主實現(xiàn)中。8.如權(quán)利要求1所述的方法,其特征在于,所述加載步驟中,使用控制反轉(zhuǎn)技術(shù)來建立起組件之間的依賴關(guān)系。9.如權(quán)利要求1或4所述的方法,其特征在于,所述的配置文件采用XML格式文件描述。全文摘要本發(fā)明提供一種分布式服務(wù)系統(tǒng)的服務(wù)提供方法,首先確定要使用的擴展接口、公共管理服務(wù)以及要提供的具體服務(wù);然后由所述具體服務(wù)實現(xiàn)所述擴展接口,并確定各服務(wù)的名稱與服務(wù)主實現(xiàn);再根據(jù)所述各服務(wù)的名稱與服務(wù)主實現(xiàn),分別生成描述各服務(wù)的配置文件;系統(tǒng)通過讀取并解析所述配置文件,分別加載各服務(wù)的主實現(xiàn);發(fā)布所述公共管理服務(wù),并將要提供的具體服務(wù)在公共管理服務(wù)上進行注冊發(fā)布。本發(fā)明克服現(xiàn)有技術(shù)中存在的訪問不一致,難于擴展,以及由于服務(wù)的添加或者更改造成的巨大連鎖反應(yīng)等問題。文檔編號G06F9/46GK1916856SQ200510090749公開日2007年2月21日申請日期2005年8月15日優(yōu)先權(quán)日2005年8月15日發(fā)明者孫鳴申請人:中興通訊股份有限公司
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
绵阳市| 阜南县| 虎林市| 綦江县| 溆浦县| 健康| 玉田县| 通城县| 喀什市| 瓦房店市| 苍山县| 临沂市| 柏乡县| 青神县| 神农架林区| 津市市| 高平市| 三门峡市| 南宁市| 石柱| 荣成市| 正安县| 青河县| 高陵县| 伊吾县| 阿瓦提县| 平南县| 都江堰市| 嘉义市| 保山市| 太谷县| 隆昌县| 阿尔山市| 浦北县| 葵青区| 鄱阳县| 开封县| 丰原市| 蒙城县| 襄汾县| 澄城县|