首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【愚公系列】2021年12月 RabbitMQ 环境搭建和初步使用(window11+vs2022+.NET 6)

【愚公系列】2021年12月 RabbitMQ 环境搭建和初步使用(window11+vs2022+.NET 6)

作者头像
愚公搬代码
发布2022-12-01 09:20:02
6930
发布2022-12-01 09:20:02
举报
文章被收录于专栏:历史专栏历史专栏

文章目录


一、RabbitMQ是啥?

RabbitMQ是使用Erlang编写的一个开源的消息队列,本身支持很多的协议:AMQP,XMPP, SMTP, STOMP,也正因如此,它非常重量级,更适合于企业级的开发。同时实现了Broker构架,这意味着消息在发送给客户端时先在中心队列排队。对路由,负载均衡或者数据持久化都有很好的支持。

它支持开放的高级消息队列协议 (AMQP,Advanced Message Queuing Protocol),从根本上避免了生产厂商的封闭,使用任何语言的各种客户都可以从中受益。这种协议提供了相当复杂的消息传输模式,所以基本上不需要MassTransit或NServiceBus的配合。它还具有“企业级”的适应性和稳定性。这些东西对我的客户来说十分的有吸引力。

二、使用步骤

1.RabbitMQ的整体架构

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2. 为什么要用RabbitMQ消息队列

消息队列是啥:消息队列(Message Queue),一种先进先出的队列结构,用于处理Message。 消息队列解决的问题:在处理大量并发请求时,同步处理往往会发生阻塞,特别是在更新数据库或者调用其他组件时。消息队列能够实现请求的异步处理、应用解耦、流量削锋和消息通讯,同时能够有效防止阻塞导致的消息丢失。 消息队列系统,一般都包含3个角色:队列服务端,队列的生产者,队列的消费者。这种架构与当下流行的分布式架构极为契合。

3. 如何安装RabbitMQ

1:安装RabbitMQ(下载地址:https://www.rabbitmq.com/install-windows.html) 2:安装完RabbitMQ-------将安装目录sbin添加到环境目录中的Path中 3:在Powershell中执行:rabbitmq-plugins list 4:安装RabbitMQ可视化管理端:rabbitmq-plugins enable rabbitmq_management 5:启动服务后访问http://localhost:15672默认的账户密码都是guest 6:修改或者删除该用户(建议先修改密码,然后添加用户,添加之后再删除guest用户,或者直接改一个密码吗保留guest用户) 7:添加一个Admin用户,名称随便,密码随便,角色选择Admin 8:添加完之后刷新Users列表会看到该用户,接下来配置hosts 9:新建一个testhost,然后点击testhost,进入host配置页面,在Permissions选项中添加admin 的访问权限 10:回到Users页面可以看到如上的列表,至此RabbitMQ配置完成

4:上述的操作可以通过以下命令完成

查看所有用户

rabbitmqctl list_users

配置权限

rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*"

查看用户权限

rabbitmqctl list_user_permissions admin

设置tag

rabbitmqctl set_user_tags admin administrator

删除用户(安全起见,删除默认用户)

rabbitmqctl delete_user guest

5. RabbitMQ的队列形式

在使用RabbitMQ之前,咱们先捋一捋RabbitMQ一共有几种使用方式,常用的5中队列

  1. 第一种:简单队列(一对一模式)耦合性高,生产消费一一对应。
  2. 第二种:WorkQueues(工作队列),一个生产,多个消费者共同处理消息。
  3. 第三种:订阅模式,1一个生产者多个消费者,每一个消费者有自己的一个队列,生产者直接将消息发送给交换机,交换机将消息发送给队列,每一个队列都需要绑定到交换机。这种模式可以满足消费者发布一个消息,多个消费者消费同一信息的需求,但C1、C2消费的都是相同的数据,有时我们需要C1和C2消费的信息只有部分差异,比如我们需求:C1消费增加的数据,C2消费编辑、增加和删除的数据。
  4. 第四种:路由模式,路由模式是在订阅模式基础上的完善,可以在生产消息的时候,加入Key值,与key值匹配的消费者消费信息。但路由模式中,就如三中提到的C1、C2、如果C2对应的类型更多,就需要写很多key值。但其实它只与C1有一点差别。
  5. 第五种:通配符模式是在路由模式的升级,他允许key模糊匹配。*代表一个词,#代表一个或多个词。通过通配符模式我们就可以将C1对应的一个key准确定为item.add。而C2我们就不需要一一写出key值,而是用item.#代替即可。

6. 以.Net Core 6控制台应用为例使用RabbitMQ

创建生产者

// See https://aka.ms/new-console-template for more information
using RabbitMQ.Client;
using System.Text;

Console.WriteLine("Hello, World!");
//创建连接工厂
ConnectionFactory factory = new ConnectionFactory
{
    UserName = "guest",//用户名
    Password = "guest",//密码
    HostName = "localhost"//rabbitmq ip
};

//创建连接
var connection = factory.CreateConnection();
//创建通道
var channel = connection.CreateModel();
//声明一个队列
channel.QueueDeclare("hello", false, false, false, null);
Console.WriteLine("\nRabbitMQ连接成功,请输入消息,输入exit退出!");
string input;
do
{
    input = Console.ReadLine();
    var sendBytes = Encoding.UTF8.GetBytes(input);
    //发布消息
    channel.BasicPublish("", "hello", null, sendBytes);
}
while (input.Trim().ToLower() != "exit");
channel.Close();
connection.Close();

创建一对一消费者

// See https://aka.ms/new-console-template for more information
using RabbitMQ.Client;
using RabbitMQ.Client.Events;
using System.Text;

Console.WriteLine("Hello, World!");
//创建连接工厂
ConnectionFactory factory = new ConnectionFactory
{
    UserName = "guest",//用户名
    Password = "guest",//密码
    HostName = "localhost"//rabbitmq ip
};
//创建连接
var connection = factory.CreateConnection();
//创建通道
var channel = connection.CreateModel();
//事件基本消费者
EventingBasicConsumer consumer = new EventingBasicConsumer(channel);
//接收到消息事件
consumer.Received += (ch, ea) =>
{
    string message = Encoding.Default.GetString(ea.Body.ToArray());

    Console.WriteLine($"收到消息: {message}");

    // Console.WriteLine($"收到该消息[{ea.DeliveryTag}] 延迟10s发送回执");
    // Thread.Sleep(10000);
    //确认该消息已被消费
    channel.BasicAck(ea.DeliveryTag, false);
    // Console.WriteLine($"已发送回执[{ea.DeliveryTag}]");
};
//启动消费者 设置为手动应答消息
channel.BasicConsume("hello", false, consumer);
Console.WriteLine("消费者已启动");
Console.ReadKey();
channel.Dispose();
connection.Close();
在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-08-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、RabbitMQ是啥?
  • 二、使用步骤
    • 1.RabbitMQ的整体架构
      • 2. 为什么要用RabbitMQ消息队列
        • 3. 如何安装RabbitMQ
          • 4:上述的操作可以通过以下命令完成
            • 5. RabbitMQ的队列形式
              • 6. 以.Net Core 6控制台应用为例使用RabbitMQ
              相关产品与服务
              消息队列 CMQ 版
              消息队列 CMQ 版(TDMQ for CMQ,简称 TDMQ CMQ 版)是一款分布式高可用的消息队列服务,它能够提供可靠的,基于消息的异步通信机制,能够将分布式部署的不同应用(或同一应用的不同组件)中的信息传递,存储在可靠有效的 CMQ 队列中,防止消息丢失。TDMQ CMQ 版支持多进程同时读写,收发互不干扰,无需各应用或组件始终处于运行状态。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档