自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

WCF MSMQ隊列基本概念簡述

開發(fā) 開發(fā)工具
WCF MSMQ隊列的類型可以被分為兩種,一種為事務性隊列,而另外一種則為非事務性隊列。接下來我們將會針對這方面知識做一個詳細介紹。

今天,我們將會在這篇文章中為大家詳細介紹一下關于WCF MSMQ隊列的一些基本特性。希望對于初學者來說,可以從這里介紹的內容中獲得一些幫助,并能夠充分掌握這些基本技巧,以方便我們的實際應用。

WCF MSMQ隊列中共有兩種類型,事務性隊列(transactional queue)會將消息持久(persiste)存儲到磁盤中,即便服務器當機(shutdown)、重啟(reboot)或崩潰(crash),消息依然可以在系統(tǒng)恢復后被讀取。同時,消息發(fā)布、獲取和刪除都在環(huán)境事務范圍內,從而確保消息的可靠性。我們還可以使用 TransactionScope 將環(huán)境事務傳遞給隊列,否則隊列會自動創(chuàng)建一個內部事務。非事務性隊列(nontransactional volatile queues)只是將消息存在內存,不會使用磁盤進行持久存儲,且不會使用事務來保護對消息的操作。一但服務器發(fā)生問題,或者調用方出現(xiàn)異常,消息都會丟失。

  1. // 創(chuàng)建事務性隊列  
  2. MessageQueue.Create(@".\private$\myqueue", true);  
  3. // 創(chuàng)建非事務性隊列  
  4. MessageQueue.Create(@".\private$\myqueue"); 

通過下面的例子我們會看到事務失敗時,沒有任何消息被寫入隊列。

  1. [ServiceContract]  
  2. public interface IService  
  3. {  
  4. [OperationContract(IsOneWay = true)]  
  5. void Test(int i);  
  6. }  
  7. [ServiceBehavior]  
  8. public class MyService : IService  
  9. {  
  10. [OperationBehavior]  
  11. public void Test(int i)  
  12. {  
  13. Console.WriteLine(i);  
  14. }  
  15. }  
  16. public class WcfTest  
  17. {  
  18. public static void Test()  
  19. {  
  20. if (!MessageQueue.Exists(@".\private$\myqueue"))  
  21. {  
  22. MessageQueue.Create(@".\private$\myqueue", true);  
  23. }  
  24. IService client = ChannelFactory<IService>.CreateChannel(  
  25. new NetMsmqBinding(NetMsmqSecurityMode.None),  
  26. new EndpointAddress("net.msmq://localhost/private/myqueue"));  
  27. try  
  28. {  
  29. using (TransactionScope scope = new TransactionScope())  
  30. {  
  31. using (client as IDisposable)  
  32. {  
  33. for (int i = 0; i < 10; i++)  
  34. {  
  35. client.Test(i);  
  36. if (i > 5) throw new Exception();  
  37. }  
  38. }  
  39. scope.Complete();  
  40. }  
  41. }  
  42. catch  
  43. {   
  44. }  
  45. AppDomain.CreateDomain("Server").DoCallBack(delegate  
  46. {  
  47. ServiceHost host = new ServiceHost(typeof(MyService),
    new Uri("net.msmq://localhost/private/myqueue"));  
  48. host.AddServiceEndpoint(typeof(IService), 
    new NetMsmqBinding(NetMsmqSecurityMode.None), "");  
  49. host.Open();  
  50. });  
  51. }  

這里需要對 "消息" 做一個澄清,當客戶端發(fā)出調用(call)時,調用會被轉換成 WCF Message,然后被包裝到 MSMQ Message 中。如果客戶端事務完成提交,那么 MSMQ Message 會被傳遞到隊列并存儲起來。相反,如果事務失敗,消息會被丟棄。上面的例子中,我們將多個調用放到一個環(huán)境事務中,也可以將多個服務調用放到一個事務當中。如果隊列服務不在當前機器上,也就是說使用 Public Queue 時,客戶端的消息隊列組件將承擔 "代理(proxy)" 的角色??蛻舳说恼{用會首先存儲到本地隊列,然后再由本地隊列轉發(fā)給目標隊列。這個轉發(fā)過程同樣受到事務保護。

要是開發(fā)非事務性消息隊列服務,需要用到 NetMsmqBinding 的兩個屬性。將 Durable 設為 false,表示不使用事務方式訪問消息隊列。另外還得將 ExactlyOnce 設為 false,否則會拋出 InvalidOperationException 異常。

下面例子中,重啟消息隊列服務(Message Queuing)后,你會發(fā)現(xiàn)消息丟失。

  1. [ServiceContract]  
  2. public interface IService  
  3. {  
  4. [OperationContract(IsOneWay = true)]  
  5. void Test(int i);  
  6. }  
  7. [ServiceBehavior]  
  8. public class MyService : IService  
  9. {  
  10. public MyService()  
  11. {  
  12. Console.WriteLine("Constructor...");  
  13. }  
  14. [OperationBehavior(TransactionScopeRequired=true)]  
  15. public void Test(int i)  
  16. {  
  17. Console.WriteLine(i);  
  18. }  
  19. }  
  20. public class WcfTest  
  21. {  
  22. public static void Test()  
  23. {  
  24. MessageQueue.Delete(@".\private$\myqueue");  
  25. MessageQueue.Create(@".\private$\myqueue");  
  26. NetMsmqBinding binding1 = new NetMsmqBinding
    (NetMsmqSecurityMode.None);  
  27. binding1.Durable = false;  
  28. binding1.ExactlyOnce = false;  
  29. IService client = ChannelFactory<IService>
    .CreateChannel(binding1,  
  30. new EndpointAddress("net.msmq://localhost/private/myqueue"));  
  31. using (client as IDisposable)  
  32. {  
  33. for (int i = 0; i < 10; i++)  
  34. {  
  35. client.Test(i);  
  36. }  
  37. }  
  38. Console.WriteLine("重啟MSMQ服務,然后按任意鍵繼續(xù)...");  
  39. Console.ReadKey(true);  
  40. AppDomain.CreateDomain("Server").DoCallBack(delegate  
  41. {  
  42. NetMsmqBinding binding2 = new NetMsmqBinding
    (NetMsmqSecurityMode.None);  
  43. binding2.Durable = false;  
  44. binding2.ExactlyOnce = false;  
  45. ServiceHost host = new ServiceHost(typeof(MyService),
    new Uri("net.msmq://localhost/private/myqueue"));  
  46. host.AddServiceEndpoint(typeof(IService), binding2, "");  
  47. host.Open();  
  48. });  
  49. }  

【編輯推薦】

  1. PDA訪問WCF實現(xiàn)重點在過程
  2. WCF標準終結點基本概念剖析
  3. WCF回調操作是雞應用技巧講解
  4. WCF元數(shù)據(jù)交換應用技巧分享
  5. IIS托管WCF服務實際操作中常見錯誤分析
責任編輯:曹凱 來源: 豆豆網
相關推薦

2010-03-01 14:50:30

WCF行為類型

2009-12-21 10:27:52

WCF基本概念

2010-02-23 16:32:29

WCF服務

2010-02-24 17:17:04

WCF宿主環(huán)境

2010-03-01 16:25:07

WCF體系架構

2009-12-21 15:33:07

WCF集合元素

2010-03-01 18:04:35

WCF配置綁定

2010-03-02 11:10:43

WCF標準終結點

2010-02-25 14:46:31

2010-03-01 16:41:04

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

2010-03-02 16:22:31

WCF狀態(tài)應用

2009-12-21 16:52:02

WCF序列化

2009-12-21 14:37:14

2009-12-22 10:16:54

WCF服務狀態(tài)

2010-03-01 17:57:11

WCF緩存機制

2010-03-03 15:10:49

第三方Python庫

2011-03-28 11:05:17

ODBC

2014-04-16 15:11:19

Spark

2009-03-20 11:46:10

MGCP協(xié)議網關

2012-09-11 14:39:03

Moosefs
點贊
收藏

51CTO技術棧公眾號