成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

WCF WS-Discovery應(yīng)用技巧分享

開發(fā) 開發(fā)工具
WCF WS-Discovery的目的就是為了定位服務(wù)定義Discovery協(xié)議,來為客戶端的搜索提供一定的幫助,其分為兩種模式,分別為:ad hoc和managed模式。

WCF是一款使用托管代碼建立的應(yīng)用程序統(tǒng)一框架。它在實際應(yīng)用中可以幫助開發(fā)人員輕松的實現(xiàn)一個安全性高,可依賴性的開發(fā)解決方案,輕松幫助用戶解決各種問題。在這里我們會為大家詳細(xì)介紹一下WCF WS-Discovery的相關(guān)應(yīng)用技巧。#t#

在WS-*標(biāo)準(zhǔn)和規(guī)范中,WCF WS-Discovery是在2008年才加入了OASIS標(biāo)準(zhǔn)。WS-Discovery在標(biāo)準(zhǔn)被定義為Web Service Dynamic Discovery,其目的是為定位服務(wù)定義Discovery協(xié)議,主要應(yīng)用在為客戶端動態(tài)搜索一個或多個目標(biāo)服務(wù)。OASIS為WS- Discovery提供了兩種操作模式:ad hoc和managed模式。

ad hoc模式根據(jù)類型在托管目標(biāo)服務(wù)的范圍內(nèi)查找目標(biāo)服務(wù)。客戶端會以多播的形式發(fā)送一個Probe(探測)消息,如果服務(wù)匹配該信息,則以單播方式直接將響應(yīng)發(fā)送到客戶端。為了能夠根據(jù)名稱定位目標(biāo)服務(wù),客戶端會以相同的多播組發(fā)送一個Resolve(解析)消息,同樣的,匹配該消息的服務(wù)會直接以單播方式響應(yīng)客戶端。

如果Endpoint的數(shù)量擴大了,且超出了ad hoc網(wǎng)絡(luò)的范圍之外,而且在網(wǎng)絡(luò)中可以使用Discovery Proxy(發(fā)現(xiàn)代理),則應(yīng)該采用Managed操作模式,以禁止多播的行為。在Managed模式下,目標(biāo)服務(wù)只需要以單播的形式發(fā)布一個 announcement(通告)消息到Discovery Proxy,同時,客戶端也會以單播形式發(fā)送Probe和Resolve消息到Discovery Proxy。這種模式并非直接采用單播方式,而是會實時對Discovery Proxy進(jìn)行監(jiān)聽,然后根據(jù)情況切換操作模式,從而降低多播給網(wǎng)絡(luò)傳輸帶來的影響。當(dāng)Discovery Proxy檢測到在ad hoc網(wǎng)絡(luò)中有多播方式發(fā)送的Probe和Resolve消息時,它就會發(fā)布announcement通知自身。客戶端一旦監(jiān)聽到Discovery Proxy上的announcement消息,就切換為Managed模式,直接以單播方式將probe和resolve消息發(fā)送給Discovery Proxy。如果Discovery Proxy沒有響應(yīng),客戶端又會切換為ad hoc操作模式。Managed模式的消息交換流程如下所示:

 

WCF 4.0實現(xiàn)了OASIS的WCF WS-Discovery標(biāo)準(zhǔn),相關(guān)的類定義在System.ServiceModel.Discovery命名空間中。這是一個單獨的程序集,所以需要添加對它的引用。

 

WCF Discoverty支持ad hoc和Managed模式,其中實現(xiàn)Managed模式需要實現(xiàn)Discovery Proxy。

在WCF 4.0中,新增了ServiceDiscoveryBehavior行為類,可以控制服務(wù)終結(jié)點的可發(fā)現(xiàn)能力。它能夠讓服務(wù)的所有終結(jié)點都能被發(fā)現(xiàn),相反,如果使用EndpointDiscoveryBehavior則只能使特定的終結(jié)點能夠被發(fā)現(xiàn)。除了需要添加發(fā)現(xiàn)行為,我們還需要添加發(fā)現(xiàn)終結(jié)點,用來指定監(jiān)聽以及發(fā)送discovery消息。WCF中標(biāo)準(zhǔn)的發(fā)現(xiàn)終結(jié)點類是UdpDiscoveryEndpoint,它基于UDP的多播綁定,是WCF 預(yù)先配置好的發(fā)現(xiàn)終結(jié)點。該終結(jié)點繼承自DiscoveryEndpoint類。在托管服務(wù)的時候,我們可以向ServiceHost中添加 ServiceDiscoveryBehavior和EndpointDiscoveryBehavior,如下所示:

  1. class CalculatorServiceHost {  
  2. public static void Main() {  
  3. Uri baseAddress = new Uri("http://localhost:8000/" + 
    Guid.NewGuid().ToString());   
  4. using (ServiceHost serviceHost = new ServiceHost(typeof
    (CalculatorService), baseAddress)) {  
  5. serviceHost.AddServiceEndpoint(typeof(ICalculatorService), 
    new WSHttpBinding(), String.Empty);  
  6. // Make the service discoverable over UDP multicast   
  7. serviceHost.Description.Behaviors.Add(new ServiceDiscoveryBehavior());   
  8. serviceHost.AddServiceEndpoint(new UdpDiscoveryEndpoint());  
  9. serviceHost.Open();  
  10. Console.WriteLine("Calculator Service started at {0}", baseAddress);  
  11. Console.WriteLine();  
  12. Console.WriteLine("Press <ENTER> to terminate the service.");  
  13. Console.WriteLine();  
  14. Console.ReadLine();  
  15. }  
  16. }  

 

在對服務(wù)宿主進(jìn)行如下設(shè)置之后,客戶端就可以通過發(fā)送Probe和Resolve消息來發(fā)現(xiàn)服務(wù)。WCF將這些邏輯封裝在了DiscoveryClient 類中。它接受一個發(fā)現(xiàn)終結(jié)點對象,然后通過調(diào)用它的Find()方法(該方法接受一個FindCriteria實例,用來指定搜索標(biāo)準(zhǔn),在下面的代碼片斷中指定搜索標(biāo)準(zhǔn)為按照目標(biāo)服務(wù)的類型),返回FindResponse對象。該對象會包含一個 Collection<EndpointDiscoveryMetadata>類型的屬性Endpoints:

  1. // Create DiscoveryClient  
  2. DiscoveryClient discoveryClient = new DiscoveryClient
    (new UdpDiscoveryEndpoint());  
  3. Console.WriteLine("Finding ICalculatorService endpoints...");  
  4. Console.WriteLine();  
  5. // Find ICalculatorService endpoints   
  6. FindResponse findResponse = discoveryClient.Find
    (new FindCriteria(typeof(ICalculatorService)));  
  7. Console.WriteLine("Found {0} ICalculatorService endpoint(s).", 
    findResponse.Endpoints.Count);  
  8. Console.WriteLine();  
  9. if (findResponse.Endpoints.Count > 0) {  
  10. return findResponse.Endpoints[0].Address;  
  11. } else {  
  12. return null;  

 

通過WCF WS-Discovery,我們不需要知道WCF服務(wù)的終結(jié)點,只要存在目標(biāo)服務(wù),我們就能夠動態(tài)查找到該服務(wù)。即使服務(wù)的Url發(fā)生改變,我們也不需要修改任何代碼和配置文件,客戶端仍然能夠正常發(fā)現(xiàn)目標(biāo)服務(wù)。

責(zé)任編輯:曹凱 來源: 博客園
相關(guān)推薦

2010-03-01 13:06:49

WCF繼承

2010-02-25 15:25:19

WCF通道

2010-02-22 17:21:02

WCF消息交換

2010-02-25 10:52:29

WCF響應(yīng)服務(wù)

2010-02-23 13:03:34

WCF序列化

2010-02-26 10:46:12

WCF行為擴展

2010-03-01 09:48:23

WCF會話服務(wù)

2010-03-01 15:40:04

WCF實例停用

2010-03-02 10:50:57

WCF元數(shù)據(jù)交換

2010-02-25 18:04:02

WCF IIS宿主

2010-03-01 17:52:03

WCF選擇綁定

2010-02-24 17:07:26

WCF序列化引擎

2010-02-22 17:58:06

WCF異步上傳

2010-02-22 11:25:50

WCF DateSet

2010-02-24 11:22:04

WCF方法重載

2009-12-22 19:00:08

WCF回調(diào)

2010-02-26 14:12:27

WCF元數(shù)據(jù)

2010-02-23 16:46:47

WCF并發(fā)能力

2010-02-22 16:19:25

WCF自托管

2010-02-22 16:26:47

WCF傳輸數(shù)據(jù)
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: www.com久久久 | 成人免费观看男女羞羞视频 | 一区二区在线不卡 | 日韩欧美国产一区二区 | 在线观看国产视频 | 国产日韩一区二区 | 一区二区国产在线观看 | 在线一区视频 | 日韩精品一区中文字幕 | 天堂资源视频 | 夜夜骑首页 | 国产精品视频播放 | 日本免费在线 | 午夜免费福利电影 | 亚洲一区二区三区 | 欧美久久久久久久 | 亚洲成人自拍 | 国产精品日韩一区二区 | 亚洲女人天堂成人av在线 | 国产视频一区二区 | 久久精品网 | 天天看天天操 | 亚洲综合色自拍一区 | 亚洲精品久久久久久国产精华液 | 国产在线视频一区二区董小宛性色 | 国产一级精品毛片 | 色婷婷亚洲国产女人的天堂 | 五月天婷婷综合 | 精品欧美一区二区中文字幕视频 | 欧美精品免费观看二区 | 91啪影院| 亚洲一区在线免费观看 | 国产偷久久一级精品60部 | 国产超碰人人爽人人做人人爱 | 黄色一级毛片 | 日韩1区| 在线免费观看日本 | 永久免费av| 综合久久综合久久 | 一级做a爰片久久毛片免费看 | 精品无码久久久久久国产 |