MSMQ菜鸟教程
一 、MSMQ概述
MSMQ全称MicroSoft Message Queue,微软消息队列,是在多个不同的应用之间实现相互通信的一种异步传输模式,相互通信的应用可以分布于同一台机器上,也可以分布于相连的网络空间中的任一位置。它的实现原理是:消息的发送者把自己想要发送的信息放入一个容器中(我们称之为Message),然后把它保存至一个系统公用空间的消息队列(Message Queue)中;本地或者是异地的消息接收程序再从该队列中取出发给它的消息进行处理。
消息Message是由通信的双方所需要传递的信息。
队列的类型主要包括一下几种:
“公共队列”在整个“消息队列”网络中复制,并且有可能由网络连接的所有站点访问。
“专用队列”不在整个网络中发布。相反,它们仅在所驻留的本地计算机上可用。专用队列只能由知道队列的完整路径名或标签的应用程序访问。
“管理队列”包含确认在给定“消息队列”网络中发送的消息回执的消息。指定希望 MessageQueue 组件使用的管理队列(如果有的话)。
“响应队列”包含目标应用程序接收到消息时返回给发送应用程序的响应消息。指定希望 MessageQueue 组件使用的响应队列(如果有的话)。
优点:稳定、消息优先级、脱机能力以及安全性,有保障的消息传递和执行许多业务处理的可靠的防故障机制。
缺点:MSMQ不适合于Client需要Server端实时交互情况.大量请求时候,响应延迟.
二 、安装启用服务
1. 控制面板 >> 程序 >> 打开或关闭Windows功能 >> Microsoft Message Queue(MSMQ)服务器,勾选消息队列服务所有选项
2. 我的电脑 >> 管理 >> 服务和应用程序 >> 消息队列 。出现消息队列则说明安装成功
三 、MSMQ编码应用举例
以下是几个常用查询代码
请先添加using System.Messaging;命名空间
1. 查询队列是否存在,值得注意的是,当访问远端消息时MSMQ不支持MessageQueue.Exists(string )等方法,所以建议直接使用new MessageQueue(QueuePath)查询
/// <summary>
/// 查询队列是否存在
/// </summary>
/// <returns></returns>
public bool QueueExist()
{
bool queueExist = false;
try
{
queueExist = MessageQueue.Exists(QueuePath);
}
catch//远端访问不支持exist,所有直接查询
{
queueExist = true;
}
return queueExist;
}
2. 创建队列,传入存储对象和注解标签
/// <summary>
/// 创建队列
/// </summary>
/// <param name="queueObj">发送到队列的对象</param>
/// <param name="queueLable">该发送队列对象的标签</param>
public void CreateQueue(object queueObj, string queueLable = "")
{
try
{
using (MessageQueue queue = QueueExist() ? new MessageQueue(QueuePath) : MessageQueue.Create(QueuePath))
{
queue.Label = queueLable;
if (queue.CanWrite)
{
queue.Send(queueObj);
}
} }
catch (Exception ex)
{
throw new Exception("Error to Create Queue!", ex);
}
}
3. 获取队列第一条数据,并删除数据
/// <summary>
/// 获取队列第一条数据,并删除数据
/// </summary>
/// <param name="queueTypes"></param>
/// <returns></returns>
public object ReceiveOneQueue(Type[] queueTypes)
{
object result = null;
if (QueueExist())
{
using (MessageQueue mq = new MessageQueue(QueuePath))
{
try
{
// 设置消息队列的格式化器
mq.Formatter = new XmlMessageFormatter(queueTypes); if (mq.CanRead)
{
Message oneMessage = mq.Receive(); // 获得消息队列中第一条消息
result = oneMessage.Body;
}
}
catch (Exception ex)
{
throw new Exception("Error to query Queue!", ex);
}
}
}
return result;
}
4. 获取队列第一条数据,但保留数据
/// <summary>
/// 获取队列第一条数据,但保留数据
/// </summary>
/// <param name="queueTypes"></param>
/// <returns></returns>
public object PeekOneQueue(Type[] queueTypes)
{
object result = null;
if (QueueExist())
{
using (MessageQueue mq = new MessageQueue(QueuePath))
{
try
{
// 设置消息队列的格式化器
mq.Formatter = new XmlMessageFormatter(queueTypes); if (mq.CanRead)
{
Message oneMessage = mq.Peek(); // 获得消息队列中第一条消息
result = oneMessage.Body;
}
}
catch (Exception ex)
{
throw new Exception("Error to query Queue!", ex);
}
}
}
return result;
}
5. 调用程序
//远程连接请使用FormatName:DIRECT=ftp://222.10.xx.xx/msmq/Private$/msmqpath
MSMQUtil.MSMQHelper msmqHelper = new MSMQUtil.MSMQHelper(@".\Private$\msmqpath");
msmqHelper.CreateQueue("first msmq", "first lable");
msmqHelper.CreateQueue(new msmqtestclass() { age = , name = "xieyang", contents = new List<string>() { "my leg", "my head" } });
var formater1 = new Type[] { typeof(string) };
object obj1 = msmqHelper.ReceiveOneQueue(formater1); var formater2 = new Type[] { typeof(msmqtestclass) };
object obj2 = msmqHelper.ReceiveOneQueue(formater2);
最常见错误: 当链接为远程时,需要给everyone读写权限。
完整代码
链接:https://pan.baidu.com/s/1lviQzuvGJFuXTqv4_7GmtA
提取码:vvxy
参考:https://docs.microsoft.com/zh-cn/dotnet/api/system.messaging?view=netframework-4.7.2
https://www.cnblogs.com/zhili/p/MSMQ.html
常见错误:https://www.cnblogs.com/mq0036/p/3695038.html
MSMQ菜鸟教程的更多相关文章
- 菜鸟教程 Python100例 之实例29
学习编程的路,走得好艰辛... 为了巩固基础知识,把菜鸟教程网上的实例拿来练习.. 在做到实例29时,看了网站给出的代码,觉得可以加强一下功能,不由得动了一下脑筋,如下: 原文题目: 题目:给一个不多 ...
- 【转载】jQuery Validate 菜鸟教程
文章1:http://www.runoob.com/jquery/jquery-plugin-validate.html (jQuery Validate 菜鸟教程)
- Http状态码大全(来自菜鸟教程)
HTTP协议(HyperText Transfer Protocol,超文本传输协议)是因特网上应用最为广泛的一种网络传输协议,所有的WWW文件都必须遵守这个标准. HTTP是一个基于TCP/IP通信 ...
- 菜鸟教程之学习Shell script笔记(下)
菜鸟教程Shell script学习笔记(下) 以下内容是学习菜鸟教程之shell教程,所整理的笔记 菜鸟教程之shell教程:http://www.runoob.com/linux/linux-sh ...
- 菜鸟教程之学习Shell script笔记(中)
菜鸟教程Shell script学习笔记(中) 以下内容是学习菜鸟教程之shell教程,所整理的笔记 菜鸟教程之shell教程:http://www.runoob.com/linux/linux-sh ...
- 菜鸟教程之学习Shell script笔记(上)
菜鸟教程之学习Shell script笔记 以下内容是,学习菜鸟shell教程整理的笔记 菜鸟教程之shell教程:http://www.runoob.com/linux/linux-shell.ht ...
- C语言经典例题(菜鸟教程100例)
学习c语言基础,怎么能少了菜鸟教程上的100道例题呢,这里整理一下每道题的链接,希望大家能享受学习的乐趣 1,有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 2,企业发放 ...
- 学习笔记之HTML 教程 | 菜鸟教程
HTML 教程 | 菜鸟教程 http://www.runoob.com/html/html-tutorial.html 菜鸟教程在线编辑器 http://www.runoob.com/try/try ...
- JavaScript 实例 | w3cschool菜鸟教程
JavaScript 实例 | w3cschool菜鸟教程 http://www.w3cschool.cc/js/js-examples.html
随机推荐
- SQL ISNULL 参数
SQL Server 中有两个参数,语法: ISNULL(check_expression, replacement_value) check_expression 与 replacement ...
- Ubuntu系统---中英文问题小记
Ubuntu系统---中英文问题小记 Ubuntu系统安装的时候,选择English版本,这样进入tty模式,中文提示不会显示乱码,终端下也是提示英文版的信息. Ubuntu 系统中文显示乱码的问题解 ...
- spark几个错误
一.java.lang.NoSuchMethodError: net.jpountz.lz4.LZ4BlockInputStream.<init>(Ljava/io/InputStream ...
- sem_open 信号量操作
sem_open,计算机用语.意思是创建并初始化有名信号量或打开一个已存在的有名信号量 sem_init:初始化信号量sem_t,初始化的时候可以指定信号量的初始值,以及是否可以在多进程间共享. se ...
- Java锁--Condition
转载请注明出处:http://www.cnblogs.com/skywang12345/p/3496716.html Condition介绍 Condition的作用是对锁进行更精确的控制.Condi ...
- 洛谷P1339 热浪【最短路】
题目:https://www.luogu.org/problemnew/show/P1339 题意:给定一张图,问起点到终点的最短路. 思路:dijkstra板子题. 很久没有写最短路了.总结一下di ...
- paramiko的使用
import paramiko import sys user = "root" pwd = " # 上传文件 def sftp_upload_file(server_p ...
- 023_STM32之PID算法原理及应用
(O)关于程序BUG说明,看最后面的红色字体,视频和源代码中都没有说明 (一)PID控制算法(P:比例 I:积分 D:微分) (二)首先先说明原理,使用的是数字PID算法,模拟PID算法在计算机这样的 ...
- 001_ARM学习_六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
以下内容为转载: 注:非常感谢博主“希望之光”,文章转自他的博客:http://blog.chinaunix.net/uid-20379123-id-1956584.html ARM的六大类指令集 ...
- bzoj 3545
bzoj 3555 离线版本 线段树合并 做法是将询问和边权都排序 给每个点建一棵线段树 然后边建mst边回答询问 每次合并两个连通块的时候 要将两个连通块的线段树合并起来 线段树合并部分code i ...