前言

上一节我们简单介绍了RabbitMQ和在安装后启动所出现的问题,本节我们开始正式进入RabbitMQ的学习,对于基本概念请从官网或者其他前辈博客上查阅,我这里不介绍基础性东西,只会简单提一下,请知悉。

RabbitMQ持久化

在RabbitMQ中存在四种交换机,一是直连交换机(Direct Exchange),二是广播交换机(Fantout Exchange),三是主题交换机(Topic Exchange),四是头交换机(Header Exchange),每种交换机都有其对应场景,后面会一一讲到。任何处理消息的开源库都离不开两个角色,一是生产者(Producer),二是消费者(Consumer),消息从生产者到达消费者需经过三个阶段也就是我们需要知道的三个概念,一是交换机,二是队列,三是绑定,初次见此三者概念感觉很高大上是不是,其实不过是高度抽象了而已,同时看到很多博客上对此三者解释的还是非常深刻,我这里就不过多细说。我们先看别人博客上对整个RabbitMQ架构用图来进行标识,然后对照我对交换机、队列、绑定一言以蔽之进行如下概括您就明白他们具体是干什么了。

交换机是生产者发布消息的入口点,队列是消费者获取消息的容器,绑定是将交换机连接到队列的规则

我们简单过一下消息从生产者到达消费者的大概过程,生产者也就是上述图中的ClientA和ClientB,发送消息到交换机,这里交换机可以是一个或者多个,然后通过路由键绑定到队列,那么消费者如何知道绑定到了哪个队列呢?然后消费者也就是上述Client1、Client2、Client3也要声明交换机、队列、绑定,这样整个过程就串起来了,原理大概就是这样。接下来我们通过代码来实现生产者发送消息(请通过NuGet安装RabbitMQ客户端)。

    public class RabbitMQService
{
public IConnection GetRabbitMQConnection()
{
var connectionFactory = new ConnectionFactory
{
HostName = "localhost",
UserName = "guest",
Password = "guest"
};
return connectionFactory.CreateConnection();
}
}

第一步当然是需要创建连接,连接到RabbitMQ服务,接下来则是在我们创建连接的基础上创建通道,然后上述我们所说消息从生产者到达消费者的过程就是在此通道上进行。

            var rabbitMQService = new RabbitMQService();
var connection = rabbitMQService.GetRabbitMQConnection();
var model = connection.CreateModel();

接下来则是声明交换机、队列、通过路由键将交换机和队列绑定在一起。

        static void InitialTopicQueue(IModel model)
{
model.QueueDeclare("queueDeclare", true, false, false, null);
model.ExchangeDeclare("exchangeDeclare", ExchangeType.Topic);
model.QueueBind("queueDeclare", "exchangeDeclare", "routeKey");
}

如上我们声明队列名称为queueDeclare且该队列持久化,然后声明交换机名称为exchangeDeclare,交换机类型为主题,最后通过QueueBind方法通过routekey路由键将声明的交换机和队列绑定在一起。接下来我们开始发布消息。

            var basicProperties = model.CreateBasicProperties();
basicProperties.DeliveryMode = ;
var payload = Encoding.UTF8.GetBytes("这是来自运行VS2017控制台发出的消息");
var address = new PublicationAddress(ExchangeType.Topic, "exchangeDeclare", "routeKey");
model.BasicPublish(address, basicProperties, payload);

然后我们在控制台中运行上述程序,然后在RabbitMQ UI上来查看声明的交换机、队列、绑定的路由键以及承载的消息。

一切如正常运行,其我们发布的消息在队列中处于Ready状态,接下来我们在服务中关闭RabbitMQ服务代理,然后重启模拟宕机的情况。

因为在声明队列中第二个参数可指定该队列是否可持久化,我们指定为True即持久化,所以即使RabbitMQ Broker重启队列依然还在,这个时候我们会发现在队列中的数据被扔掉了,也就是说此时的队列为空。那是因为我们指定消息为非持久化,如下指定传输模式即DeliveryModel属性为1,1代表非持久化,2为可持久化。所以如果我们指定DeliveryMode等于2即使RabbitMQ代理宕机,重启后消息依然还在。

            var basicProperties = model.CreateBasicProperties();
basicProperties.DeliveryMode = ;

同理切换到ExchangeType界面时,此时我们声明的交换机不存在了,如下:

因为声明交换机时ExchangeDeclare方法有重载,第三个参数可指定是否持久化,默认为非持久化,如果我们进行如下指定为持久化,那么和在队列中的消息一样即使RabbitMQ代理重启交换机依然还在,这个就不需要我再过多啰嗦了。

 model.ExchangeDeclare("exchangeDeclare", ExchangeType.Topic, true);

从如上演示我们可看出在RabbitMQ中关于持久化,可对交换机(ExChange)、队列(Queue)、消息(Message)分别指定持久化,而且在大部分情况下这也是我们想要的。因为这至少可以保证消息从生产者传递消费者的过程中不会丢失。那么对于持久化和非持久化RabbitMQ是如何进行处理的呢?

持久化:将消息保存到磁盘上,因此即使在服务器重新启动后它们仍然可用,只不过在读取和保存消息时会产生一些额外的开销罢了。

非持久化:将消息被保存在内存中,虽然它们在服务器重启后将会消失,但提供更快的消息处理。

总结

今天我们详细讲解了RabbitMQ中的持久化,我们可从交换机、队列、消息三个层面去设置持久化。这只是小试牛刀,下节开始讨论细枝末节,学习的过程也是发现问题的过程,我们下节再会。

学习在.NET Core中使用RabbitMQ进行消息传递之持久化(二)的更多相关文章

  1. 在ABP core中使用RabbitMq

    距上一篇博客的更新一集很久了,主要是最近做的事情比较杂,中间也有一个难点,就是在ABP中加入APP扫码登录,本来想些的,但是觉得这个写出来会不会让我们的系统被破解-_-||,所以想了想,就没有写. 这 ...

  2. .NET Core中使用RabbitMQ正确方式

    .NET Core中使用RabbitMQ正确方式 首先甩官网:http://www.rabbitmq.com/ 然后是.NET Client链接:http://www.rabbitmq.com/dot ...

  3. WSL2+Docker部署RabbitMQ以及在Asp.net core 中使用RabbitMQ示例(1)

    本文主要在于最近因疫情不能外出,在家研究的一些技术积累. 主要用到的技术以及知识点: WSL 2 WSL 2+Docker Docker+RabbitMQ 在ASP.NET Core中使用Rabbit ...

  4. 3、带你一步一步学习ASP.NET Core中的配置之Configuration

    如果你是刚接触ASP.NET Core的学习的话,你会注意到:在ASP.NET Core项目中,看不到.NET Fraemwork时代中的web.config文件和app.config文件了.那么你肯 ...

  5. 在.Net Core中使用MongoDB的入门教程(二)

    在上一篇文章中,讲到了MongoDB在导入驱动.MongoDB的连接,数据的插入等. 在.Net Core中使用MongoDB的入门教程(一) 本篇文章将接着上篇文章进行介绍MongoDB在.Net ...

  6. SpringBoot学习笔记(11)-----SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用

    1. activemq 首先引入依赖 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId& ...

  7. DotNet Core中使用RabbitMQ

    上一篇随笔记录到RabbitMQ的安装,安装完成,我们就开始使用吧. RabbitMQ简介 AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协 ...

  8. .Net Core中使用RabbitMQ

    (1).引入依赖 RabbitMQ.Client (2).编写发布者代码 var connectionFactory = new ConnectionFactory() { HostName=&quo ...

  9. 在.Net Core中使用MongoDB的入门教程(一)

    首先,我们在MongoDB的官方文档中看到,MongoDb的2.4以上的For .Net的驱动是支持.Net Core 2.0的. 所以,在我们安装好了MangoDB后,就可以开始MangoDB的.N ...

随机推荐

  1. Spring Boot面试题

    Spring Boot 是微服务中最好的 Java 框架. 我们建议你能够成为一名 Spring Boot 的专家. 问题一 Spring Boot.Spring MVC 和 Spring 有什么区别 ...

  2. windows server 2016远程桌面进去,英文系统修改语言

    由于我这边已经是改好了,以下截图来自中文版. 这边选了中文,然后点options. 选择:使该语言成为主要语言,保存. 会提示需要退出登录. 过一会重新登录,ok.

  3. 最小二乘法多项式拟合的Java实现

    背景 由项目中需要根据一些已有数据学习出一个y=ax+b的一元二项式,给定了x,y的一些样本数据,通过梯度下降或最小二乘法做多项式拟合得到a.b,解决该问题时,首先想到的是通过spark mllib去 ...

  4. Java面试题—初级(1)

    1.一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 可以有多个类,但只能有一个public的类,并且public的类名必须与文件名相一致. 2.Java有 ...

  5. shell多进程脚本

    #!/bin/bash python_path=/home/huaw/crawler python_name=list_all_v6_crawler.py MAX_SYNC_PROCESS=40 ec ...

  6. Django项目实战之用户上传与访问

    1 将文件保存到服务器本地 upload.html <!DOCTYPE html> <html lang="en"> <head> <me ...

  7. 单例模式详解及java常用类

    [单例模式]      确保某一个类,只能产生一个实例. 设计思路: ====将构造函数私有化,确保类外部,不能使用new关键字自行创建对象. ====在类内部实例化一个对象,并通过静态方法返回. ( ...

  8. Swing图层的应用——实现tooltip显示

    没有错是世纪前的swing. 在使用Swing的时候有个问题一直没有解决,就是Swing自带的tooltip不会跟随鼠标进行移动,而且移动到边界就会遮挡的问题.JCompoent有个createToo ...

  9. 使用 C# (.NET Core) 实现模板方法模式 (Template Method Pattern)

    本文的概念内容来自深入浅出设计模式一书. 项目需求 有一家咖啡店, 供应咖啡和茶, 它们的工序如下: 咖啡: 茶: 可以看到咖啡和茶的制作工序是差不多的, 都是有4步, 其中有两步它们两个是一样的, ...

  10. 远程连接服务器jupyter notebook、浏览器以及深度学习可视化方法

    h1 { counter-reset: h2counter; } h2 { counter-reset: h3counter; } h3 { counter-reset: h4counter; } h ...