返回顶部
首页 > 资讯 > 精选 >C#如何利用RabbitMQ实现点对点消息传输
  • 697
分享到

C#如何利用RabbitMQ实现点对点消息传输

2023-06-15 02:06:23 697人浏览 薄情痞子
摘要

这篇文章主要介绍C#如何利用RabbitMQ实现点对点消息传输,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!消息队列模型所有 MQ 产品从模型抽象上来说都是一样的过程:消费者(consumer)订阅某个队列。生产者(

这篇文章主要介绍C#如何利用RabbitMQ实现点对点消息传输,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

消息队列模型

所有 MQ 产品从模型抽象上来说都是一样的过程:
消费者(consumer)订阅某个队列。生产者(producer)创建消息,然后发布到队列(queue)中,最后将消息发送到监听的消费者。

C#如何利用RabbitMQ实现点对点消息传输

RabbitMQ设置

RabbitMQ是通过交换机将消息转发到对应队列,所以队列需要和交换机进行绑定。本例将队列绑定到默认的amq.direct交换机,并设置Routing key,如下图所示:

C#如何利用RabbitMQ实现点对点消息传输

RabbitMQ动态库安装

通过NuGet包管理器进行安装RabbitMQ.Client,如下所示:

C#如何利用RabbitMQ实现点对点消息传输

RabbitMQ.Client相关知识点

  • ConnectionFactory:构造一个实例,主要创建连接。

  • IConnection:表示一个基于AMQP协议的连接。

  • IModel:表示一个RabbitMQ通道,可用于声明一个队列,然后开始消费。

  • EventingBasicConsumer:基于独立事件监听的基础消费者,可以监听并接收消息。

  • 生产者基本步骤:1. 创建连接 2. 基于连接创建通道 3. 基于通道声明队列,4. 开始生产并发布消息

  • 消费者基本步骤:1. 创建连接 2. 基于连接创建通道 3. 基于通道声明队列,4. 创建消费者,5. 绑定通道和消费者,并开始消费

示例效果图

本例主要有一个生产者,一个消费者,通过消息队列进行消息转发和接收。

生产者负责消息发送,如下图所示:

C#如何利用RabbitMQ实现点对点消息传输

消费者负责消息接收,如下图所示:

C#如何利用RabbitMQ实现点对点消息传输

核心代码

代码结构:主要包括生产者,消费者,公共基础代码,如下所示:

C#如何利用RabbitMQ实现点对点消息传输

RabbitMqHelper主要创建连接,如下所示:

public class RabbitMqHelper    {        /// <summary>        /// 创建连接        /// </summary>        /// <returns></returns>        public IConnection GetConnection()        {            try            {                var factory = new ConnectionFactory()                {                    HostName = "127.0.0.1",                    Port = 5672,                    UserName = "guest",                    PassWord = "guest",                    VirtualHost = "/ShortMsgHost"                };                var conn = factory.CreateConnection();                return conn;            }            catch (Exception ex) {                throw ex;            }        }    }

RabbmitMqSendHelper用于发送消息,如下所示:

public class RabbmitMqSendHelper : RabbitMqHelper    {        /// <summary>        /// 发送消息        /// </summary>        /// <param name="msg"></param>        /// <returns></returns>        public bool SendMsg(string msg)        {            try            {                using (var conn = GetConnection())                {                    using (var channel = conn.CreateModel())                    {                        channel.QueueDeclare(queue: "ShortMsgQueue",                                     durable: true,                                     exclusive: false,                                     autoDelete: false,                                     arguments: null);                        var body = Encoding.UTF8.GetBytes(msg);                        channel.BasicPublish(exchange: "amq.direct",                                             routingKey: "ShortMsgKey",                                             basicProperties: null,                                             body: body);                        //Console.WriteLine(" [x] Sent {0}", message);                    };                };                return true;            }            catch (Exception ex)            {                throw ex;            }        }    }

RabbitMqReceiveHelper主要用于接收信息,如下所示:

public class RabbitMqReceiveHelper : RabbitMqHelper    {        public RabbitMqReceiveEventHandler OnReceiveEvent;        private IConnection conn;        private IModel channel;        private EventingBasicConsumer consumer;        public bool StartReceiveMsg()        {            try            {                conn = GetConnection();                channel = conn.CreateModel();                channel.QueueDeclare(queue: "ShortMsgQueue",                                durable: true,                                exclusive: false,                                autoDelete: false,                                arguments: null);                consumer = new EventingBasicConsumer(channel);                consumer.Received += (model, ea) =>                {                    var body = ea.Body.ToArray();                    var message = Encoding.UTF8.GetString(body);                    //Console.WriteLine(" [x] Received {0}", message);                    if (OnReceiveEvent != null)                    {                        OnReceiveEvent(message);                    }                };                channel.BasicConsume(queue: "ShortMsgQueue",                                        autoAck: true,                                        consumer: consumer);                return true;            }            catch (Exception ex)            {                throw ex;            }        }    }

C#是什么

C#是一个简单、通用、面向对象编程语言,它由微软Microsoft开发,继承了C和c++强大功能,并且去掉了一些它们的复杂特性,C#综合了VB简单的可视化操作和C++的高运行效率,以其强大的操作能力、优雅的语法风格、创新的语言特性和便捷的面向组件编程从而成为.net开发的首选语言,但它不适用于编写时间急迫或性能非常高的代码,因为C#缺乏性能极高的应用程序所需要的关键功能。

以上是“C#如何利用RabbitMQ实现点对点消息传输”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: C#如何利用RabbitMQ实现点对点消息传输

本文链接: https://lsjlt.com/news/276924.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C#如何利用RabbitMQ实现点对点消息传输
    这篇文章主要介绍C#如何利用RabbitMQ实现点对点消息传输,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!消息队列模型所有 MQ 产品从模型抽象上来说都是一样的过程:消费者(consumer)订阅某个队列。生产者(...
    99+
    2023-06-15
  • C#利用RabbitMQ实现点对点消息传输
    目录消息队列模型RabbitMQ设置RabbitMQ动态库安装RabbitMQ.Client相关知识点示例效果图核心代码消息队列模型 所有 MQ 产品从模型抽象上来说都是一样的过程...
    99+
    2024-04-02
  • SpringBoot如何使用WebSocket实现点对点消息
    这篇文章主要介绍“SpringBoot如何使用WebSocket实现点对点消息”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SpringBoot如何使用WebSocket实现点对点消息”文章能帮助大...
    99+
    2023-07-06
  • 怎么用SpringBoot+RabbitMQ实现消息可靠传输
    这篇文章主要介绍了怎么用SpringBoot+RabbitMQ实现消息可靠传输的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用SpringBoot+RabbitMQ实现消息可靠传输文章都会有所收获,下面我们...
    99+
    2023-06-30
  • SpringBoot+RabbitMQ实现消息可靠传输详解
    目录环境配置消息丢失分析生产阶段生产端模拟消息丢失RabbitMQ消费端环境配置 SpringBoot 整合 RabbitMQ 实现消息的发送。 1.添...
    99+
    2024-04-02
  • SpringBoot中怎么使用WebSocket实现点对点消息
    本篇内容介绍了“SpringBoot中怎么使用WebSocket实现点对点消息”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、添加依赖,配...
    99+
    2023-06-08
  • C#如何用RabbitMQ实现消息订阅与发布
    这篇文章给大家分享的是有关C#如何用RabbitMQ实现消息订阅与发布的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Fanout交换机模型扇形交换机,采用广播模式,根据绑定的交换机,路由到与之对应的所有队列。一个...
    99+
    2023-06-15
  • 如何利用rabbitMq的死信队列实现延时消息
    目录前言mq基本的消息模型mq死信队列的消息模型maven依赖配置普通队列和死信队列死信队列消费者发送消息测试测试成功总结前言 使用mq自带的死信去实现延时消息要注意一个坑点,就是m...
    99+
    2023-01-28
    rabbitMq死信队列 rabbitMq延时消息 rabbitMq延时队列
  • 前端与RabbitMQ实时消息推送未读消息小红点实现示例
    目录引言RabbitMQ 搭建1、开启 mqtt 协议服务端消息发送1、mqtt 客户端依赖包2、消息发送者前端消息订阅测试总结 引言 前几天粉丝群里有个小伙伴问过:web ...
    99+
    2024-04-02
  • C#用RabbitMQ实现消息订阅与发布
    目录Fanout交换机模型RabbitMQ控制台操作新增两个队列绑定fanout交换机示例效果图核心代码消息发布消息订阅Fanout交换机模型 扇形交换机,采用广播模式,根据绑定的...
    99+
    2024-04-02
  • C#如何实现局域网点对点
    这篇文章主要介绍“C#如何实现局域网点对点”,在日常操作中,相信很多人在C#如何实现局域网点对点问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#如何实现局域网点对点”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-17
  • Android利用Badge组件实现未读消息小红点
    目录前言Badge 组件实例总结前言 在 App 的运营中,活跃度是一个重要的指标,日活/月活……为了提高活跃度,就发明了小红点,然后让强迫症用户&ldq...
    99+
    2023-01-14
    Android Badge实现消息未读红点 Android 消息未读红点 Android Badge组件
  • 如何利用Redis和C++实现消息订阅功能
    如何利用Redis和C++实现消息订阅功能消息订阅是现代应用程序开发中常见的一种通信模式,它可以实现实时消息推送和数据更新通知。Redis是一个高性能的内存数据库,它支持发布-订阅模式,并且提供了丰富的功能和API,使得在C++中使用Red...
    99+
    2023-10-22
    C++ redis 消息订阅
  • 如何使用Redis实现点赞取消点赞
    这篇文章将为大家详细讲解有关如何使用Redis实现点赞取消点赞,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码实现:    private void&n...
    99+
    2023-06-29
  • 详解SpringBoot整合RabbitMQ如何实现消息确认
    目录简介生产者消息确认介绍流程配置ConfirmCallbackReturnCallback注册ConfirmCallback和ReturnCallback消费者消息确认介绍手动确认...
    99+
    2024-04-02
  • C++如何实现成对交换节点
    这篇文章主要讲解了“C++如何实现成对交换节点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++如何实现成对交换节点”吧!Swap Nodes in Pairs 成对交换节点Given a...
    99+
    2023-06-19
  • java如何使用UDP实现点对点通信
    本文小编为大家详细介绍“java如何使用UDP实现点对点通信”,内容详细,步骤清晰,细节处理妥当,希望这篇“java如何使用UDP实现点对点通信”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。整体的结构思路:Stu...
    99+
    2023-07-02
  • 如何使用C++实现HTTP流传输?
    如何在 c++++ 中实现 http 流传输?使用 boost.asio 和 asiohttps 客户端库创建 ssl 流套接字。连接到服务器并发送 http 请求。接收 http 响应...
    99+
    2024-05-12
    c++ http
  • Html5中怎么利用postMessage实现跨域消息传递
    Html5中怎么利用postMessage实现跨域消息传递,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、同源策略  &...
    99+
    2024-04-02
  • 怎么在HTML5中利用WebSocket实现点对点聊天
    这期内容当中小编将会给大家带来有关怎么在HTML5中利用WebSocket实现点对点聊天,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。首先在系统启动的时候调用InitServlet方法public&nbs...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作