我的编程空间,编程开发者的网络收藏夹
学习永远不晚

WCF分布式开发之MSMQ消息队列

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

WCF分布式开发之MSMQ消息队列

一、MSMQ简介

MSMQ(微软消息队列)是Windows操作系统中消息应用程序的基础,是用于创建分布式、松散连接的消息通讯应用程序的开发工具。

MSMQ与XML Web Services和.Net Remoting一样,是一种分布式开发技术。但是在使用XML Web Services或.Net Remoting组件时,Client端需要和Server端实时交换信息,Server需要保持联机。MSMQ则可以在Server离线的情况下工作,将Message临时保存在Client端的消息队列中,以后联机时再发送到Server端处理。

1、MSMQ的实现原理

消息的发送者把自己想要发送的信息放入一个容器,然后把它保存到一个系统公用空间的消息队列中,本地或异地的消息接收程序再从该队列中取出发给它的消息进行处理。

消息队列是一个公用存储空间,它可以存在于内存中或物理文件中,因此,消息以两种方式发送,即快递方式和可恢复模式。MSMQ机制类似QQ消息传递机制。下图演示了MSMQ的实现原理。

2、安装

默认情况下安装操作系统是不安装消息队列的,你可以在控制面板中找到添加/删除程序,然后选择添加/删除Windows组件一项,然后选择应用程序服务器,双击它进入详细资料中选择消息队列一项进行安装。

如果服务没有自动启动,需要启动服务: 
这里写图片描述

3、两个概念

一个是消息Message:Message是通信双方需要传递的消息,它可以是文本、图片、视频等。消息包含发送和接收者的标识,只有指定的用户才能取得消息。

另一个是队列Queue:用来保存消息的存储空间,消息对列分为3类:

  • 公共队列:MachineName\QueueName 
    能被别的机器所访问,如果你的多个项目中用到消息队列,那么你可以把队列定义为公共队列
  • 专用队列:MachineName\Private$\QueueName 
    只针对于本机的程序才可以调用的队列,有些情况下为了安全起见定义为私有队列。
  • 日志队列:MachineName\QueueName\Journal$

4、MicroSoft.Message.Queue常用的方法:

  • Create方法:创建使用指定路径的新消息队列。
  • Delete方法:删除现有的消息队列。
  • Existe方法:查看指定消息队列是否存在。
  • GetPublicQueues方法:在“消息队列”网络中定位消息队列。
  • Send方法:发送消息到指定的消息队列。
  • GetAllMessages()方法:得到队列中的所有消息。
  • Receive/BeginReceive方法:检索指定消息队列中最前面的消息,并将其从该队列中移除
  • Peek/BeginPeek方法:查看某个特定队列中的消息队列,但不从该队列中移出消息。。
  • Purge方法:清空指定队列的消息。

二、服务端

首先,实现服务器端。创建一个控制台项目,添加System.Messaging引用,因为消息队列的类全部封装在System.Messaging.dll程序集里。

服务器端代码需要注意的是,公共队列只能在域环境中创建,如果个人电脑没有加入域环境,则不能创建公共队列。

    if (!MessageQueue.Exists(@".\MYFIRSTMSMQ"))
    {
        using (MessageQueue mq = MessageQueue.Create(@".\MYFIRSTMSMQ"))//创建一个公共消息队列
        {
            mq.Label = "myFirstMSMQ";
            Console.WriteLine("已经创建了一个公共队列{0}", mq.Label);
            Console.WriteLine("公共队列{0}的路径为{1}", mq.Label, mq.Path);
            mq.Send("MSMQ 消息", "今天又学到个有趣的知识");
        }
    }
    foreach (MessageQueue mq in MessageQueue.GetPublicQueues())//获取所有公共队列,发送消息
    {
        mq.Send("发送公共消息队列" + DateTime.Now.ToLongTimeString(), "今天又学到个有趣的知识");
        Console.WriteLine("公有消息已经送到{0}", mq.Path);
    }

    if (!MessageQueue.Exists(@".\Private$\MYFIRSTMSMQ"))
    {
        using (MessageQueue mq = MessageQueue.Create(@".\Private$\MYFIRSTMSMQ"))//创建一个私有消息队列
        {
            mq.Label = "myFirstPrivateMSMQ";
            Console.WriteLine("已经创建了一个私有队列{0}", mq.Label);
            Console.WriteLine("私有队列{0}的路径为{1}", mq.Label, mq.Path);
            mq.Send("MSMQ 私有队列消息" + "今天又学到个有趣的知识");
        }
    }

    if (MessageQueue.Exists(@".\Private$\MYFIRSTMSMQ"))
    {
        MessageQueue mq = new MessageQueue(@".\Private$\MYFIRSTMSMQ");//找到私有队列,发送消息

        mq.Send("发送私有消息队列" + DateTime.Now.ToLongTimeString() + "今天又学到个有趣的知识");
        Console.WriteLine("私有消息已经送到{0}", mq.Path);
    }

三、客户端

服务器端把消息发送到共享的消息队列中,然后,客户端从这个共享的消息队列中取出消息进行处理。

if (MessageQueue.Exists(@".\MYFIRSTMSMQ"))// 获取公共消息队列
{
    using (MessageQueue mq = new MessageQueue(@".\MYFIRSTMSMQ"))//创建消息队列对象
    {
        mq.Formatter = new XmlMessageFormatter(new string[] { "System.String" });//设置消息队列的格式化器,还有BinaryMessageFormatter,ActiveXMessageFormatter等
        foreach (Message msg in mq.GetAllMessages())
        {
            Console.WriteLine("接收到的消息是:{0}", msg.Body);
        }
        Message firstmsg = mq.Receive();
        Console.WriteLine("收到的第一条消息为:{0}", firstmsg.Body);
    }
}

if (MessageQueue.Exists(@".\Private$\MYFIRSTMSMQ"))// 获取私有消息队列
{
    using (MessageQueue mq = new MessageQueue(@".\Private$\MYFIRSTMSMQ"))
    {
        //....
    }
}

到此这篇关于WCF分布式开发之MSMQ消息队列的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

WCF分布式开发之MSMQ消息队列

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C#开发中如何处理分布式事务和消息队列

C#开发中如何处理分布式事务和消息队列引言:在今天的分布式系统中,事务和消息队列是非常重要的组件。在处理数据一致性和系统解耦方面,分布式事务和消息队列起着至关重要的作用。本文将介绍如何在C#开发中处理分布式事务和消息队列,并给出具体的代码示
2023-10-22

怎么用c#写开源分布式消息队列equeue

这篇文章主要介绍“怎么用c#写开源分布式消息队列equeue”,在日常操作中,相信很多人在怎么用c#写开源分布式消息队列equeue问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用c#写开源分布式消息队列
2023-06-17

分布式消息队列RocketMQ概念详解

RocketMQ 是阿里开源的分布式消息中间件,跟其它中间件相比,RocketMQ 的特点是纯JAVA实现,是一套提供了消息生产,存储,消费全过程API的软件系统,本文详细介绍了分布式消息队列RocketMQ概念,需要的朋友可以参考下
2023-05-19

深入理解redis分布式锁和消息队列

最近博主在看redis的时候发现了两种redis使用方式,与之前redis作为缓存不同,利用的是redis可设置key的有效时间和redis的BRPOP命令。 分布式锁 由于目前一些编程语言,如PHP等,不能在内存中使用锁,或者如Java这
2022-06-04

Go语言开发实现分布式消息队列系统的方法与实践

在当今互联网高并发和大规模数据处理的背景下,分布式消息队列系统作为一种重要的中间件技术日益受到关注。它可以有效地缓解系统压力,提高系统的可扩展性和可靠性。Go语言由于其并发模型、高性能和简洁的特点,在开发分布式消息队列系统中具有独特的优势。
Go语言开发实现分布式消息队列系统的方法与实践
2023-11-20

android开发教程之使用looper处理消息队列

代码如下:package com.yanjun; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import andro
2022-06-06

消息队列RabbitMQ核心:简单(Hello World)模式、队列(Work Queues)模式、发布确认模式

文章目录 一、简单模式(Hello World)代码实现 二、队列模式(Work Queues)轮训分发消息代码实现 消息应答概述 RabbitMQ持久化不公平分发 三、发布确认模式原理概述发布确认策略单个确认
2023-08-23

分布式系统中 Golang 函数与消息队列的集成

在分布式系统中,集成函数和消息队列可实现解耦、可扩展性和弹性,通过使用以下步骤在 golang 中集成:创建 cloud functions 函数。集成消息队列客户端库。处理队列消息。订阅消息队列主题。分布式系统中 Golang 函数与消息
分布式系统中 Golang 函数与消息队列的集成
2024-04-19

如何进行下一代分布式消息队列Apache Pulsar的分析

如何进行下一代分布式消息队列Apache Pulsar的分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Pulsar简介Apache Pulsar是一个企业级
2023-06-02

如何使用Redis和Kotlin开发分布式队列功能

如何使用Redis和Kotlin开发分布式队列功能引言:随着互联网的迅速发展,分布式系统越来越受到关注。分布式队列是分布式系统的重要组成部分之一,能够实现消息的异步处理和解耦。本文将介绍如何使用Redis和Kotlin开发一个简单的分布式队
2023-10-22

Swoole和Workerman的消息队列与分布式系统的集成和扩展能力

首先,我们先了解一下Swoole和Workerman的特点。Swoole是一个面向生产环境的PHP异步网络通信引擎,支持TCP/UDP/Unix Socket/HTTP/WebSocket等协议,提供了定时器、异步任务、子进程管理等功能。W
2023-10-21

如何利用Redis和Python开发分布式任务队列功能

如何利用Redis和Python开发分布式任务队列功能简介:随着互联网应用的发展,对于实时性和并发处理能力的需求越来越高,分布式任务队列成为解决并发任务处理的重要工具。本文将详细介绍如何利用Redis和Python开发分布式任务队列功能,并
2023-10-22

如何使用Redis和PowerShell开发分布式消息通信功能

如何使用Redis和PowerShell开发分布式消息通信功能概述:在分布式系统中,消息通信是一个很重要的组件。它可以实现各个系统之间的实时信息传递和同步,提高系统的可靠性和性能。Redis是一个高性能的键值存储数据库,广泛应用于分布式系统
2023-10-22

如何利用Redis和Python开发分布式消息推送功能

如何利用Redis和Python开发分布式消息推送功能一、简介随着互联网的快速发展,实时消息推送功能成为了现代应用中非常重要的一部分。为了实现高并发和分布式的消息推送功能,我们可以利用Redis和Python来实现。二、Redis简介Red
2023-10-22

使用Go语言开发高可用的分布式消息中间件

使用Go语言开发高可用的分布式消息中间件随着互联网的飞速发展,越来越多的应用需求需要实现大规模的消息传递和处理。而传统的单机消息队列在处理大压力下的消息流量时表现出了明显的性能瓶颈,因此分布式消息中间件的需求逐渐增加。Go语言作为一门高效且
使用Go语言开发高可用的分布式消息中间件
2023-11-20

SpringCloud分布式微服务b2b2c电子商务(十二)在springboot中用redis实现消息队列

准备阶段安装redis,可参考我的另一篇文章java 1.8maven 3.0idea环境依赖创建一个新的springboot工程,了解springcloud架构可以加求求:三五三六二四七二五九。在其pom文件,加入spring-boot-
2023-06-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录