.Net消息队列的使用

版权声明:作者:真爱无限 出处:http://blog.csdn.net/pukuimin1226 本文为博主原创文章版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接.

.Net使用消息队列,借助windows组件来存储要完成的一系列任务,不用程序使用同一个队列,方便不同程序之间的数据共享和协作……

以本人经验,这个在某个方面类似于session(当然还有很多方面不同),相同之处:session可以把信息存储在aspnet_state服务中,网站重新编译或者重新启动网站,session不会丢失(session超时是正常情况,这种情况除外)。

win7中安装消息队列组件,其他操作系统请百度搜索相关资料。

如果服务没有自动启动,需要启动服务:

先创建队列,再使用队列,队列中的消息,发送一个多一个,接收一个少一个,先进先出。

[csharp] view plain copy

print?

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.UI;
  6. using System.Web.UI.WebControls;
  7. using System.Messaging;
  8. //添加物理文件 System.Messaging 的引用
  9. namespace testweb
  10. {
  11. public partial class MSMQtest : System.Web.UI.Page
  12. {
  13. protected void Page_Load(object sender, EventArgs e)
  14. {
  15. //CreateNewQueue("MsgQueue");//创建一个消息队列
  16. //sendSimpleMsg();//每一个队列最好只发送和接收同一种格式的信息,不然不好转换格式。
  17. //receiveSimpleMsg();//
  18. //receiveSimpleMsg();
  19. //sendComplexMsg();
  20. //receiveComplexMsg();
  21. MsgModel m = receiveComplexMsg<MsgModel>();
  22. Response.Write(m.ToString());
  23. }
  24. private void sendSimpleMsg()
  25. {
  26. //实例化MessageQueue,并指向现有的一个名称为VideoQueue队列
  27. MessageQueue MQ = new MessageQueue(@".\private$\MsgQueue");
  28. //MQ.Send("消息测试", "测试消息");
  29. System.Messaging.Message message = new System.Messaging.Message();
  30. message.Label = "消息lable";
  31. message.Body = "消息body";
  32. MQ.Send(message);
  33. Response.Write("成功发送消息," + DateTime.Now + "<br/>");
  34. }
  35. private void receiveSimpleMsg()
  36. {
  37. MessageQueue MQ = new MessageQueue(@".\private$\MsgQueue");
  38. //调用MessageQueue的Receive方法接收消息
  39. if (MQ.GetAllMessages().Length > 0)
  40. {
  41. System.Messaging.Message message = MQ.Receive(TimeSpan.FromSeconds(5));
  42. if (message != null)
  43. {
  44. //message.Formatter = new System.Messaging.XmlMessageFormatter(new string[] { "Message.Bussiness.VideoPath,Message" });//消息类型转换
  45. message.Formatter = new System.Messaging.XmlMessageFormatter(new Type[] { typeof(string) });
  46. Response.Write(string.Format("接收消息成功,lable:{0},body:{1},{2}<br/>", message.Label, message.Body.ToString(), DateTime.Now));
  47. }
  48. }
  49. else
  50. {
  51. Response.Write("没有消息了!<br/>");
  52. }
  53. }
  54. private void sendComplexMsg()
  55. {
  56. //实例化MessageQueue,并指向现有的一个名称为VideoQueue队列
  57. MessageQueue MQ = new MessageQueue(@".\private$\MsgQueue");
  58. //MQ.Send("消息测试", "测试消息");
  59. System.Messaging.Message message = new System.Messaging.Message();
  60. message.Label = "复杂消息lable";
  61. message.Body = new MsgModel("1", "消息1");
  62. MQ.Send(message);
  63. Response.Write("成功发送消息,"+DateTime.Now+"<br/>");
  64. }
  65. private void receiveComplexMsg()
  66. {
  67. MessageQueue MQ = new MessageQueue(@".\private$\MsgQueue");
  68. //调用MessageQueue的Receive方法接收消息
  69. if (MQ.GetAllMessages().Length > 0)
  70. {
  71. System.Messaging.Message message = MQ.Receive(TimeSpan.FromSeconds(5));
  72. if (message != null)
  73. {
  74. message.Formatter = new System.Messaging.XmlMessageFormatter(new Type[] { typeof(MsgModel) });//消息类型转换
  75. MsgModel msg = (MsgModel)message.Body;
  76. Response.Write(string.Format("接收消息成功,lable:{0},body:{1},{2}<br/>", message.Label, msg, DateTime.Now));
  77. }
  78. }
  79. else
  80. {
  81. Response.Write("没有消息了!<br/>");
  82. }
  83. }
  84. private T receiveComplexMsg<T>()
  85. {
  86. MessageQueue MQ = new MessageQueue(@".\private$\MsgQueue");
  87. //调用MessageQueue的Receive方法接收消息
  88. if (MQ.GetAllMessages().Length > 0)
  89. {
  90. System.Messaging.Message message = MQ.Receive(TimeSpan.FromSeconds(5));
  91. if (message != null)
  92. {
  93. message.Formatter = new System.Messaging.XmlMessageFormatter(new Type[] { typeof(T) });//消息类型转换
  94. T msg = (T)message.Body;
  95. return msg;
  96. }
  97. }
  98. return default(T);
  99. }
  100. /// <summary>
  101. /// 创建消息队列
  102. /// </summary>
  103. /// <param name="name">消息队列名称</param>
  104. /// <returns></returns>
  105. public void CreateNewQueue(string name)
  106. {
  107. if (!System.Messaging.MessageQueue.Exists(".\\private$\\" + name))//检查是否已经存在同名的消息队列
  108. {
  109. System.Messaging.MessageQueue mq = System.Messaging.MessageQueue.Create(".\\private$\\" + name);
  110. mq.Label = "private$\\"+name;
  111. Response.Write("创建成功!<br/>");
  112. }
  113. else
  114. {
  115. //System.Messaging.MessageQueue.Delete(".\\private$\\" + name);//删除一个消息队列
  116. Response.Write("已经存在<br/>");
  117. }
  118. }
  119. }
  120. [Serializable]
  121. public class MsgModel
  122. {
  123. public string id { get; set; }
  124. public string Name { get; set; }
  125. public MsgModel() { }
  126. public MsgModel(string _id, string _Name)
  127. {
  128. id = _id;
  129. Name = _Name;
  130. }
  131. public override string ToString()
  132. {
  133. if (string.IsNullOrEmpty(id) || string.IsNullOrEmpty(Name)) return "";
  134. return string.Format("id--{0},Name--{1}",id,Name);
  135. }
  136. }
  137. }
时间: 2024-10-15 15:20:06

.Net消息队列的使用的相关文章

Azure Messaging-ServiceBus Messaging消息队列技术系列6-消息回执

上篇博文中我们介绍了Azure Messaging的重复消息机制.At most once 和At least once. Azure Messaging-ServiceBus Messaging消息队列技术系列5-重复消息:at-least-once at-most-once 本文中我们主要研究并介绍Azure Messaging的消息回执机制:实际应用场景: 同步收发场景下,消息生产者和消费者双向应答模式,例如:张三写封信送到邮局中转站,然后李四从中转站获得信,然后在写一份回执信,放到中转站

【转】MSMQ 微软消息队列 简单 示例

MSMQ它的实现原理是:消息的发送者把自己想要发送的信息放入一个容器中(我们称之为Message),然后把它保存至一个系统公用空间的消息队列(Message Queue)中:本地或者是异地的消息接收程序再从该队列中取出发给它的消息进行处理. 我个人的理解,你可以把他当做一种,把数据打包后,发送到一个地方,程序也可以去取到这个打包的程序,队列的机制就不讲了,并发问题荡然无存.呵呵. 上代码: 首先 using System.Messaging; public class MsmqManagerHe

消息队列(msg)

一.消息队列:从一个进程向另一个进程发送数据块,读取不一定是先入先出. 管道与消息队列区别:管道基于字节流的,消息队列基于消息: 管道只能发送字符串,消息队列有类型: 管道随进程,消息队列随内核. 二.创建函数原型:int msgget(key_t key, int msgflg);    //key由ftok生成,IPC_CREAT|IPC_EXCL 接收消息:ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp, in

第15章 进程间通行 15.6 XSI IPC 15.7 消息队列

15.6 XSI IPC (1)3种称作XSI IPC的IPC是: 1)消息队列 2)信号量 3)共享存储器 (2)标识符和键 1)标识符:是一个非负整数,用于引用IPC结构.是IPC对象的内部名. 2)键:IPC对象的外部名.可使多个合作进程能够在同一IPC对象上汇聚. (3)IPC_PRIVATE键: 用于创建一个新的IPC结构.不能指定此键来引用一个现有的IPC结构. (4)ftok函数: 由一个路径名和项目ID产生一个键. (5)ipc_perm结构体 规定了ipc结构的权限和所有者.

XSI进程间通信-----消息队列

1. 基本特点 1) 消息队列是一个由系统内核负责存储和管理,并通过消息队列标识引用的数据链表,消息队列 和有名管道fifo的区别在: 后者一次只能放一个包,而前者则可以放很多包,这样就能处理发包快,哪包慢的问题 2) 可以通过msgget函数创建一个新的消息队列, 或获取一个已有的消息队列. 通过msgsnd函数 (send)向消息队列的后端追加消息, 通过msgrcv(receive)函数从消息队列的前端提取消息. 3) 消息队列中的每个消息单元除包含消息数据外,还包含消息类型和数据长度.消

android 中使用View的消息队列api更新数据

基本上只要继承自View的控件,都具有消息队列或者handler的一些处理方法,下面是一些handler方法以及被View封装了的方法,其底层用的基本都是handler的api. 我么开一下postDelay的定义 android.view.View  public boolean postDelayed(Runnable action, long delayMillis) {         final AttachInfo attachInfo = mAttachInfo;         

消息队列实现订单异步提交

what MSMQ(Microsoft Message Queue),微软消息队列,用于应用程序之间相互通信的一种异步传输模式.应用程序可以分布在同台机器上,也可以分布于互联的网络中的任意位置.基本原理:消息发送者把要发送的消息放入容器,也就是Message(消息),然后保存到系统公用空间的消息队列中(Message Queue)中,本地或互联位置上的消息接收程序再从队列中取出发给它的消息进行处理.消息类型可以是文本,图像,自定义对象等.消息队列分为公共队列和私有队列. why 一.用于进程间的

Windows消息队列

一 Windows中有一个系统消息队列,对于每一个正在执行的Windows应用程序,系统为其建立一个"消息队列",即应用程序队列,用来存放该程序可能 创建的各种窗口的消息.应用程序中含有一段称作"消息循环"的代码,用来从消息队列中检索这些消息并把它们分发到相应的窗口函数中.  二 Windows为当前执行的每个Windows程序维护一个「消息队列」.在发生输入事件之后,Windows将事件转换为一个「消息」并将消息放入程序的消息队列中.程序通过执行一块称之为「消息循

消息队列编程

消息队列:就是一个消息的链表.而一条消息则可看作一个记录,具有特定的格式.进程可以向中按照一定的规则添加新消息:另一些进程则可以从消息队列中读走消息 发送消息队列: #include<sys/types.h>#include<sys/msg.h>#include<sys/ipc.h>#include<stdio.h> struct msgt{ long msgtype; char msgtext[1024]; };int msg_type;char str[

Freertos-事件标志组,消息队列,信号量,二值信号量,互斥信号量

任务间的通信和同步机制  在裸机编程时,使用全局变量的确比较方便,但是在加上 RTOS 后就是另一种情况了. 使用全局变量相比事件标志组主要有如下三个问题: 1.使用事件标志组可以让 RTOS 内核有效地管理任务,而全局变量是无法做到的,任务的超时等机制需要用户自己去实现.2.使用了全局变量就要防止多任务的访问冲突,而使用事件标志组则处理好了这个问题,用户无需担心.3.使用事件标志组可以有效地解决中断服务程序和任务之间的同步问题. 事件标志组:事件标志组是实现多任务同步的有效机制之一. 每创建一