日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

我的WCF之旅(12):使用MSMQ进行Reliable Messaging(转载)

發布時間:2025/5/22 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 我的WCF之旅(12):使用MSMQ进行Reliable Messaging(转载) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、為什么要使用MSMQ

在一個分布式的環境中,我們往往需要根據具體的 情況采用不同的方式進行數據的傳輸。比如在一個Intranet內,我們一般通過TCP進行高效的數據通信;而在一個Internet的環境中,我們則通 常使用Http進行跨平臺的數據交換。而這些通信方式具有一個顯著的特點,那就是他們是基于Connection的,也就是說,交互雙方在進行通信的時候 必須保證有一個可用的Connection存在于他們之間。而在某些時候,比如那些使用撥號連接的用戶、以及使用便攜式計算機的用戶,我們不能保證在他們 和需要訪問的Server之間有一個的可靠的連接,在這種情況下,基于Messaging Queue的連接就顯得尤為重要了。我們今天就來談談在WCF中如何使用MSMQ。

MSMQ不僅僅是作為支持客戶端連接工具而存在,合理的使用MSMQ可以在很大程度上提升系統的Performance和Scalability。我們先來看看MSMQ能給我們帶來怎樣的好處:

1.MSMQ是基于Disconnection

MSMQ通過Message Queue進行通信,這種通信方式為離線工作成為了可能。比如在介紹MSMQ時都會提到的Order Delivery的例子:在一個基于B2C的系統中,訂單從各種各樣的客戶傳來,由于 客戶的各異性,不能保證每個客戶在每時每刻都和用于接收訂單的Server保持一個可靠的連接,我們有時候甚至允許客戶即使在離線的 情況下也可以遞交訂單(雖然訂單不能發送到訂單的接收方,但是我們可以通過某種機制保證先在本地保存該訂單,一旦連接建立,則馬上向接收方遞交訂單),而 MSMQ則有效地提供了這樣的機制:Server端建立一個Message Queue來接收來個客戶的訂單,客戶端通過向該Message Queue發送承載了訂單數據的Message實現訂單的遞交。如果在客戶離線的情況下,他仍然可以通過客戶端程序進行訂單遞交的操作,存儲著訂單數據的 Message會被暫時保存在本地的Message Queue中,一旦客戶聯機,MSMQ將Message從中取出,發送到真正的接收方,而這個動作對于用戶的透明的。

2.MSMQ天生是One-way、異步的

在MSMQ中,Message始終以One-way的方式進行發送,所以MSMQ具有天生的異步特性。所以MSMQ使用于那些對于用戶的請求,Server端無需立即響應的場景。也就是說Server對數據的處理無需和Client的數據的發送進行同步,它可以獨自地按照自己的Schedule進行工作。這可以避免峰值負載。比如Server端可以在一個相對低負載的時段(比如深夜)來對接收到的Order進行批處理,而無需一天24小時一直進行Order的監聽、接收和處理。

3.MSMQ能夠提供高質量的Reliable Messaging

我們知道,在一般的情況下,如果Client端 以異步的方式對Service進行調用就意味著:Client無法獲知Message是否成功抵達Service端;也不會獲得Service端執行的結 果和出錯信息。但是我們仍然說MSMQ為我們提供了可靠的傳輸(Reliable Messaging),這主要是因為MSMQ為我們提供一些列Reliable Messaging的機制:

  • 超時機制(Timeout):可以設置發送和接收的時間,超出該時間則被認為操作失敗。
  • 確認機制(Acknowledgement):當Message成功抵達Destination Queue,或者被成功接收,向發送端發送一個Acknowledgement message用以確認操作的狀態。
  • 日志機制(Journaling):當Message被發送或接收后,被Copy一份存放在Journal Queue中。

此外,MSMQ還提供了死信隊列(Dead letter Queue)用以保存發送失敗的message。這一切保證了保證了Reliable Messaging。

二、?MSMQ在WCF的運用

在WCF中,MSMQ提供的數據傳輸功能被封裝在一個Binding中,提供WCF Endpoint之間、以及Endpoint和現有的基于MSMQ的Application進行通信的實現。為此WCF為我們提供了兩種不同的built-in binding:

  • NetMsmqBinding: 從提供的功能和使用 方式上看,NetMsmqBinding和一般使用的binding,比如basicHttpBinding,netTcpBinding沒有什么區別: 在兩個Endpoint之間實現了數據的通信,所不同的是,它提供的是基于MSMQ的Reliable Messaging。從變成模式上看,和一般的binding完全一樣。
  • MsmqIntegrationBinding: 從命名上我們可以看出,MsmqIntegrationBinding主要用于需要將我們的WCF Application和現有的基于MSMQ的Application集成的情況。MsmqIntegrationBinding實現了WCF Endpoint和某個Message Queue進行數據的通信,具體來說,就是實現了單一的向某個Message Queue 發送Message,和從某個Message Queue中接收Message的功能。從編程模式上看,也有所不同,比如Operation只接收一個MsmqMessage<T>的參數。

這是Client和Service通信的圖示:

三、MSMQ和Transaction

MSMQ提供對Transaction的支持。在一般的情況下,MSMQ通過Message Queue Transaction實現對Transaction的原生的支持,借助Message Queue Transaction,可以把基于一個或多個Message Queue的相關操作納入同一個Transaction中。

Message Queue Transaction僅僅限于基于Message Queue的操作,倘若操作涉及到另外一些資源,比如SQL Server, 則可以使用基于DTC的分布式Transaction

對于WCF中MSMQ,由于Client和Service的相對獨立(可能Client發送Message到Service處理Message會相隔很長一段時間),所以Client和Service的操作只能納入不同的Transaction中,如下圖。

四、Sample1:NetMsmqBinding

我們首先做一個基于NetMsmqBinding Sample,實現的功能就是我們開篇所提出的Order Delivery。我們說過,NetMsmqBinding和一般的binding在實現的功能和變成模式上完全一樣。下面是我們熟悉的4層結構:


1.Contract

DataContract:Order & OrderItem

using?System;
using?System.Collections.Generic;
using?System.Text;
using?System.Runtime.Serialization;

namespace?Artech.QueuedService.Contract
{
????[DataContract]
????[KnownType(
typeof(OrderItem))]
????
public?class?Order
????
{
????????
Private?Fields

????????
Constructors

????????
Public?Properties

????????
Public?Methods
????}

}


using?System;
using?System.Collections.Generic;
using?System.Text;
using?System.Runtime.Serialization;

namespace?Artech.QueuedService.Contract
{
????[DataContract]
????
public?class?OrderItem
????
{
????????
Private?Fields

????????
Constructors

????????
Public?Properties
????}

}

?

ServiceContract: IOrderProcessor

using?System;
using?System.Collections.Generic;
using?System.Text;
using?System.ServiceModel;

namespace?Artech.QueuedService.Contract
{
????[ServiceContract]?
????[ServiceKnownType(
typeof(Order))]
????
public?interface?IOrderProcessor
????
{
????????[OperationContract(IsOneWay?
=?true)]
????????
void?Submit(Order?order);
????}

}

2.Service:IOrderProcessor

using?System;
using?System.Collections.Generic;
using?System.Text;
using?Artech.QueuedService.Contract;
using?System.ServiceModel;

namespace?Artech.QueuedService.Service
{
????
public?class?OrderProcessorService:IOrderProcessor
????
{
????????
ISubmitOrder?Members
????}

}

using?System;
using?System.Collections.Generic;
using?System.Text;
using?Artech.QueuedService.Contract;

namespace?Artech.QueuedService.Service
{
????
public?static?class?Orders
????
{
????????
private?static?IDictionary<Guid,?Order>?_orderList?=?new?Dictionary<Guid,?Order>();

????????
public?static?void?Add(Order?order)
????????
{
????????????_orderList.Add(order.OrderNo,?order);
????????}


????????
public?static?Order?GetOrder(Guid?orderNo)
????????
{
????????????
return?_orderList[orderNo];
????????}

????}

}

3.Hosting

Configuration

<?xml?version="1.0"?encoding="utf-8"??>
<configuration>
????
<system.serviceModel>
????????
<bindings>
????????????
<netMsmqBinding>
????????????????
<binding?name="msmqBinding">
????????????????????
<security>
????????????????????????
<transport?msmqAuthenticationMode="None"?msmqProtectionLevel="None"?/>
????????????????????????
<message?clientCredentialType="None"?/>
????????????????????
</security>
????????????????
</binding>
????????????
</netMsmqBinding>
????????
</bindings>
????????
<services>
????????????
<service?name="Artech.QueuedService.Service.?OrderProcessorService">
????????????????
<endpoint?address="net.msmq://localhost/private/orders"?binding="netMsmqBinding"
????????????????????bindingConfiguration
="msmqBinding"?contract="Artech.QueuedService.Contract.IOrderProcessor"?/>
????????????
</service>
????????
</services>
????
</system.serviceModel>
</configuration>

在默認的情況下,netMsmqBinding 的msmqAuthenticationModeWindowsDomain,由于基于WindowsDomain必須安裝AD,利于在本機模擬,我把msmqAuthenticationMode改為None,相應的ProtectionLevel和clientCredentialType改為None。

Program:

using?System;
using?System.Collections.Generic;
using?System.Text;
using?System.Messaging;
using?System.ServiceModel;
using?Artech.QueuedService.Service;

namespace?Artech.QueuedService.Hosting
{
????
class?Program
????
{
????????
static?void?Main(string[]?args)
????????
{
????????????
string?path?=?@".\private$\orders";
????????????
if(!MessageQueue.Exists(path))
????????????
{
????????????????MessageQueue.Create(path,
true);
????????????}


????????????
using?(ServiceHost?host?=?new?ServiceHost(typeof(OrderProcessorService)))
????????????
{
????????????????host.Opened?
+=?delegate
????????????????
{
????????????????????Console.WriteLine(
"Service?has?begun?to?listen\n\n");
????????????????}
;

????????????????host.Open();

????????????????Console.Read();
????????????}

????????}

????}

}

在Host Service之前,通過MessageQueue.Create創建一個Message Queue,第二個參數為表明Queue是否支持Transaction的indicator,這里支持Transaction。

4.Client:

Configuration

<?xml?version="1.0"?encoding="utf-8"??>
<configuration>
????
<system.serviceModel>
????????
<bindings>
????????????
<netMsmqBinding>
????????????????
<binding?name="msmqBinding">
????????????????????
<security>
????????????????????????
<transport?msmqAuthenticationMode="None"?msmqProtectionLevel="None"?/>
????????????????????????
<message?clientCredentialType="None"?/>
????????????????????
</security>
????????????????
</binding>
????????????
</netMsmqBinding>
????????
</bindings>
????????
<client>
????????????
<endpoint?address="net.msmq://localhost/private/orders"?binding="netMsmqBinding"
????????????????bindingConfiguration
="msmqBinding"?contract="Artech.QueuedService.Contract.IOrderProcessor"
????????????????name
="defaultEndpoint"?/>
????????
</client>
????
</system.serviceModel>
</configuration>

Program

using?System;
using?System.Collections.Generic;
using?System.Text;
using?Artech.QueuedService.Contract;
using?System.ServiceModel;
using?System.Transactions;

namespace?Artech.QueuedService.Client
{
????
class?Program
????
{
????????
static?void?Main(string[]?args)
????????
{
????????????ChannelFactory
<IOrderProcessor>?channelFactory?=?new?ChannelFactory<IOrderProcessor>("defaultEndpoint");
????????????IOrderProcessor?channel?
=?channelFactory.CreateChannel();

????????????Order?order?
=?new?Order(Guid.NewGuid(),DateTime.Today,Guid.NewGuid(),"A?Company");
????????????order.OrderItems.Add(
new?OrderItem(Guid.NewGuid(),"PC",5000,20));
????????????order.OrderItems.Add(
new?OrderItem(Guid.NewGuid(),"Printer",7000,2));

????????????Console.WriteLine(
"Submit?order?to?server");
????????????
using?(TransactionScope?scope?=?new?TransactionScope(TransactionScopeOption.Required))
????????????
{?
?????????????????channel.Submit(order);
?????????????????scope.Complete();
????????????}
???????
????????????Console.Read();
????????}

????}

}

先后運行Host和Client,Host端有下面的輸出:

轉載于:https://www.cnblogs.com/zpc870921/archive/2012/09/10/2678629.html

總結

以上是生活随笔為你收集整理的我的WCF之旅(12):使用MSMQ进行Reliable Messaging(转载)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久久久久久久久久久久久久久久 | 一区二区手机在线 | 可以看黄色的网站 | 日韩激情视频在线 | 午夜老司机福利 | 黄色一级网| a√在线视频 | 狠狠做深爱婷婷综合一区 | 女人扒开双腿让男人捅 | 在线看污片 | 成人短视频在线 | 国产又大又粗又爽 | 一级黄色片国产 | 国产成人在线视频观看 | 男人的天堂在线观看av | jlzzjlzz亚洲日本少妇 | 毛茸茸多毛bbb毛多视频 | 久久青青草原 | 免费毛片基地 | 久精品在线 | 美日韩成人av | 亚洲国产成 | 成人app在线| 久久久久综合网 | 欧美在线小视频 | 激情综合站 | 午夜精品影院 | 亚洲性生活片 | 亚洲国产无线乱码在线观看 | 尤物视频最新网址 | 欧美精品区 | 香蕉视频| 久久精品黄色片 | 国产一区二区免费 | 一级黄色片欧美 | 亚洲色吧 | 天堂av网址| 欧美专区在线视频 | 97青青草 | 色综合五月 | 欧美日韩国产一区二区在线观看 | 成人综合在线观看 | 国产成人精品免高潮费视频 | 亚洲成人日韩 | 91成人免费在线视频 | 新版天堂资源中文8在线 | 亚洲男女激情 | 国产又粗又猛又爽又黄无遮挡 | 乱人伦xxxx国语对白 | 超碰在线观看99 | www.色就是色.com | 国产欧美视频一区二区三区 | 亚洲第一天堂在线观看 | 精品国自产拍在线观看 | 亚洲一区二区三区高清视频 | 欧美成人精品一区二区 | 爱爱网站视频 | 本站只有精品 | 一区二区日韩电影 | 91搞搞| 黄色三级免费观看 | 97超碰人人爱 | 国产片91 | 亚洲熟妇av日韩熟妇在线 | 嫩草嫩草嫩草嫩草 | 中文写幕一区二区三区免费观成熟 | 午夜一级视频 | 狠狠爱视频 | 亚洲第十页 | 美女露胸软件 | 一区二区三区免费毛片 | 久久久久久人妻一区二区三区 | 日日夜夜天天综合 | 香蕉视频网站在线观看 | 日本啊v在线 | 国产在线精品二区 | 亚洲男人的天堂在线 | 91麻豆精品国产91久久久更新时间 | 国产区久久 | 中文字幕人妻一区 | 国产区精品在线观看 | 亚洲免费观看高清完整版在线 | 中文字幕黄色 | 国产精品丝袜在线 | 少妇极品熟妇人妻无码 | 欧美日一区二区三区 | 青青青在线视频观看 | 国产视频精品一区二区三区 | 色999视频| 久久99精品久久久久 | china国产乱xxxxx绿帽 | 国产免费av观看 | 日韩欧美国产激情 | 最新福利在线 | 亚洲熟妇毛茸茸 | 国产美女激情 | 久久一区二 | 狠狠操你 | 久久理伦 |