前言

我们在.Net中使用RabbitMQ,最原始的就是基于RabbitMQ.Client进行编码,在这个过程中我们需要通过代码约定和维护队列,Exchange等。如果是自行编码封装通用型的RabbitMQ组件还是比较麻烦的,那么是否已经有比较优秀的RabbitMQ封装组件呢----EasyNetQ就是一个封装比较好并且非常方便使用的组件。

EasyNetQ是什么?

EasyNetQ是在RabbitMQ.Client库之上提供服务的组件集合(基于RabbitMQ.Client的进一步封装)。这些封装包括序列化,错误处理,线程编组,连接管理等。它们由mini-IoC容器组成。我们可以轻松地用自己的实现替换任何组件。EasyNetQ官方网站http://easynetq.com/

以下就是EasyNetQ官网的api设计结构图和部分描述信息

.NetCore中简单使用EasyNetQ

注:安装并配置好RabbiMQ(略)

一、注入EasyNetQ

1) 配置RabbitMQ连接信息

"RabbitMqConnetion": "host=localhost;virtualHost=test_vh;username=qingy;password=r3295"

2)在startup.cs中注入EasyNetQ

            //注入easynetQ
string mqConnetion = Configuration["RabbitMqConnetion"];
services.AddSingleton(RabbitHutch.CreateBus(mqConnetion));

二、定义消息实体,并实现发送接收消息

1)、定义消息实体和对应业务处理类

   [Queue("qingy.SimpleMessaggeCommand", ExchangeName = "qingy.SimpleMessaggeCommand")]
public class SimpleMessaggeCommand
{
/// <summary>
/// Id
/// </summary>
public Guid Id { get; set; }
/// <summary>
/// Message
/// </summary>
public string Message { get; set; }
/// <summary>
/// 消息时间
/// </summary>
public DateTime MessageTime { get; set; }
}

其中[Queue("qingy.SimpleMessaggeCommand", ExchangeName = "qingy.SimpleMessaggeCommand")],可以不指定。easynetq会自动生成相应的queue和exchange,但是为了便于阅读还是指定名称比较好。

订阅消息业务处理

 1     public class MyService : IConsumeAsync<SimpleMessaggeCommand>
2 {
3 /// <summary>
4 /// 处理SimpleMessaggeCommand
5 /// </summary>
6 /// <param name="message"></param>
7 /// <returns></returns>
8 [AutoSubscriberConsumer(SubscriptionId = "Simple.SimpleMessagge")]
9 [SubscriptionConfiguration(PrefetchCount = 20)]
10 public Task ConsumeAsync(SimpleMessaggeCommand message)
11 {
12 //TODO logic here
13 Console.WriteLine($"{message.Id.ToString()}---{message.Message}--{message.MessageTime.ToString("yyyy-MM-dd HH:mm:ss")}");
14 return Task.CompletedTask;
15 }
16 }
 [AutoSubscriberConsumer(SubscriptionId = "Simple.SimpleMessagge")]  声明subscriptionid,如果确定只有一个订阅者,可以不声明。
[SubscriptionConfiguration(PrefetchCount = 20)] 声明并发处理的数量,一般调试时可以设置为1,进行单条调试测试。

2)注入消息订阅

 1         /// <summary>
2 /// 注入消息订阅
3 /// </summary>
4 /// <param name="app"></param>
5 /// <param name="subscriptionPrefix"></param>
6 /// <param name="assembly"></param>
7 /// <returns></returns>
8 public static IApplicationBuilder UseMqSubscribe(this IApplicationBuilder app, string subscriptionPrefix, Assembly assembly)
9 {
10 var services = app.ApplicationServices;
11 var lifeTime = services.GetService<IHostApplicationLifetime>();
12 var bus = services.GetService<IBus>();
13 lifeTime.ApplicationStarted.Register(() =>
14 {
15 var subscriber = new AutoSubscriber(bus, subscriptionPrefix) {
16
17 };
18 subscriber.Subscribe(assembly);
19 subscriber.SubscribeAsync(assembly);
20 });
21 lifeTime.ApplicationStopped.Register(()=> {
22 bus.Dispose();
23 });
24 return app;
25 }

在startup.cs的Configure方法中添加

            var ass = Assembly.LoadFrom(Path.Combine(AppContext.BaseDirectory, "Qingy.HubServie.dll"));
app.UseMqSubscribe("Simple", ass);

三、运行测试

.NetCore中简单使用EasyNetQ的更多相关文章

  1. Netcore中简单使用MemoryCache

    用到缓存架构,我们一般都会想到的Redis,因为它支持分布式,高可用,速率非常快.MemoryCache则相对较少提到,但是对于单体项目或者小型项目,memorycache还是是不错的选择.Memor ...

  2. netcore中的缓存介绍

    Cache(缓存)是优化web应用的常用方法,缓存存放在服务端的内存中,被所有用户共享.由于Cache存放在服务器的内存中,所以用户获取缓存资源的速度远比从服务器硬盘中获取快,但是从资源占有的角度考虑 ...

  3. .NetCore中EFCore的使用整理(二)-关联表查询

    EF常用处理关联加载的方式有3中:延迟加载(Lazy Loading).贪婪加载 (Eager Loading)以及显示加载. 一.EF Core  1.1 1.当前的版本,还不支持延迟加载(Lazy ...

  4. .NetCore中EFCore for MySql整理(三)之Pomelo.EntityFrameworkCore.MySql

    一.Pomelo.EntityFrameworkCore.MySql简介 Git源代码地址:https://github.com/PomeloFoundation/Pomelo.EntityFrame ...

  5. .NetCore中三种注入方式的思考

    该篇内容由个人博客点击跳转同步更新!转载请注明出处! .NetCore彻底诠释了"万物皆可注入"这句话的含义,在.NetCore中到处可见注入的使用.因此core中也提供了三种注入 ...

  6. 深入剖析.NETCORE中CORS(跨站资源共享)

    前言 由于现代互联网的飞速发展,我们在开发现代 Web 应用程序中,经常需要考虑多种类型的客户端访问服务的情况:而这种情况放在15年前几乎是不可想象的,在那个时代,我们更多的是考虑怎么把网页快速友好的 ...

  7. .netcore中的依赖注入

    IOC.DI相关概念的理解 1.依赖:简单的讲就是"引用到".例如AccountController.cs引用到IAccountService.cs,那么AccountContro ...

  8. 中介者模式及在NetCore中的使用MediatR来实现

    在现实生活中,常常会出现好多对象之间存在复杂的交互关系,这种交互关系常常是"网状结构",它要求每个对象都必须知道它需要交互的对象.例如,每个人必须记住他(她)所有朋友的电话:而且, ...

  9. Asp.NetCore 中Aop的应用

    前言 其实好多项目中,做一些数据拦截.数据缓存都有Aop的概念,只是实现方式不一样:之前大家可能都会利用过滤器来实现Aop的功能,如果是Asp.NetCore的话,也可能会使用中间件: 而这种实现方式 ...

随机推荐

  1. C1853 编译器错误:fatal error C1853: 'pjtname.pch' precompiled header file is from a previous

    转载:https://www.cnblogs.com/emanlee/archive/2010/10/16/1852998.html 用VC++ 2008 编写C语言程序,编译出现错误: 预编译头文件 ...

  2. 全方位剖析 Linux 操作系统,太全了!!!

    Linux 简介 UNIX 是一个交互式系统,用于同时处理多进程和多用户同时在线.为什么要说 UNIX,那是因为 Linux 是由 UNIX 发展而来的,UNIX 是由程序员设计,它的主要服务对象也是 ...

  3. TP5发送邮件

    1,前提去qq邮箱开启smtp 2,生成授权码 2,发送短信给 3,附上代码 贴上代码如下 <?phpnamespace app\mails\controller;use \think\Cont ...

  4. 你还在手撕微服务?快试试 go-zero 的微服务自动生成

    0. 为什么说做好微服务很难? 要想做好微服务,我们需要理解和掌握的知识点非常多,从几个维度上来说: 基本功能层面 并发控制&限流,避免服务被突发流量击垮 服务注册与服务发现,确保能够动态侦测 ...

  5. 多测师讲解htm_L标题标签001_高级讲师 肖sir

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>百 ...

  6. Jenkins环境搭建(7)-集成钉钉消息推送

    在去年的时候,搭建了一套Jenkins环境,基本功能已实现,可以通过如下地址查阅. Jenkins环境搭建(1)-下载与安装 Jenkins环境搭建(2)-搭建jmeter+ant+jenkins自动 ...

  7. es 迁移数据, 重建索引

    原索引 PUT my_index { "mappings": { "_doc": { "properties": { "creat ...

  8. python接口测试之日志功能

    之前在简书中看了一篇关于日志功能的文档,供大家参考:https://www.jianshu.com/p/62f7b49b41e7 Python通过logging模块提供日志功能,所以直接导入即可 im ...

  9. Spark学习总结

    RDD及其特点 1.RDD是Spark的核心数据模型,但是个抽象类,全称为Resillient Distributed Dataset,即弹性分布式数据集. 2.RDD在抽象上来说是一种元素集合,包含 ...

  10. 为什么说 Python 内置函数并不是万能的?

    本文出自"Python为什么"系列,请查看全部文章 在Python猫的上一篇文章中,我们对比了两种创建列表的方法,即字面量用法 [] 与内置类型用法 list(),进而分析出它们在 ...