热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

rabbitmq查看消费者_.netCore3.1使用RabbitMQ(一)

1.为什么要用消息队列消息队列是啥:消息队列(MessageQueue),一种先进先出的队列结构,用于处理Me
db49b19759bac9ac1f7030b487dbbe07.png

1. 为什么要用消息队列

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

2. RabbitMQ是啥

  • RabbitMQ是使用Erlang编写的一个开源的消息队列,本身支持很多的协议:AMQP,XMPP, SMTP, STOMP,也正因如此,它非常重量级,更适合于企业级的开发。同时实现了Broker构架,这意味着消息在发送给客户端时先在中心队列排队。对路由,负载均衡或者数据持久化都有很好的支持。
7f627b5272d2b15d5fbf331f78d257e3.png
  • 它支持开放的高级消息队列协议 (AMQP,Advanced Message Queuing Protocol),从根本上避免了生产厂商的封闭,使用任何语言的各种客户都可以从中受益。这种协议提供了相当复杂的消息传输模式,所以基本上不需要MassTransit或NServiceBus的配合。它还具有“企业级”的适应性和稳定性。这些东西对我的客户来说十分的有吸引力。
d3df567723a47f5f10d0eeadcead12f5.png
RabbitMQ的整体架构

3. 如何安装RabbitMQ

  • 安装RabbitMQ(下载地址:https://github.com/rabbitmq/rabbitmq-server/releases/tag/v3.7.26)(安装之前先安装 Erlang)
099e16798947e7eaf91936f8020262c1.png
cfdeb333490383682674171ea8c41440.png
6f2f6082031336983413134626bb2425.png
将sbin添加到环境目录中的Path中
efeb37342ebfa8df611cb9ad3b2e92f0.png
在Powershell中执行:rabbitmq-plugins list
b76fd77ccddf36e334a75600c1793caa.png
安装RabbitMQ可视化管理端:rabbitmq-plugins enable rabbitmq_management

默认的账户密码都是guest

37433e05d5e892f48b27f2c317d0ac6e.png
登录之后的页面
8bce680fb3afd292d7a8d85cb53b60d0.png
修改或者删除该用户(建议先修改密码,然后添加用户,添加之后再删除guest用户,或者直接改一个密码吗保留guest用户)
8c9a4baa0c0c44338feee53fa375ac00.png
添加一个Admin用户,名称随便,密码随便,角色选择Admin
aee487dd6081fc6238183bf4dace58cd.png
添加完之后刷新Users列表会看到该用户,接下来配置hosts
8a15c6faf6e772bf318e3228e63672fa.png
新建一个testhost,然后点击testhost,进入host配置页面,在Permissions选项中添加admin 的访问权限
a14dab777bc273c20cc8967401a75dcb.png
回到Users页面可以看到如上的列表,至此RabbitMQ配置完成

TIPS:上述操作也可以通过命令行来完成

查看所有用户

rabbitmqctl list_users

添加一个用户

rabbitmqctl add_user admin 123456

配置权限

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

查看用户权限

rabbitmqctl list_user_permissions admin

设置tag

rabbitmqctl set_user_tags admin administrator

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

rabbitmqctl delete_user guest

4afd7a6a7e769037420a0ee0f96f6533.png

4. 先了解一下RabbitMQ的队列形式

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

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

5. .net Core3.1如何优雅的使用RabbitMQ

2d8826e646cebf6f9837534b9180c11e.png
新建控制台应用程序,引入RabbitMQ.Client包

创建生产者

using RabbitMQ.Client;
using System;
using System.Text;namespace RabbitMQTest
{///

/// 生产者/// class Program{static void Main(string[] args){//创建连接工厂ConnectionFactory factory = new ConnectionFactory{UserName = "admin",//用户名Password = "lmt456123",//密码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();}}
}

创建一对一消费者

using RabbitMQ.Client;
using RabbitMQ.Client.Events;
using System;
using System.Text;namespace RabbitMQConsumer
{///

/// 消费者/// class Program{static void Main(string[] args){//创建连接工厂ConnectionFactory factory = new ConnectionFactory{UserName = "admin",//用户名Password = "lmt456123",//密码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();}}
}

启动程序并测试

f5a6c4845b3bdcbc4515c3b8e3610585.png

一对一的消费队列咱们就此创建完成,下一节开始RabbitMQ的高级用法



推荐阅读
  • 深入解析 Synchronized 锁的升级机制及其在并发编程中的应用
    深入解析 Synchronized 锁的升级机制及其在并发编程中的应用 ... [详细]
  • CAS 机制下的无锁队列设计与实现 ... [详细]
  • 深入解析Spring Boot启动过程中Netty异步架构的工作原理与应用
    深入解析Spring Boot启动过程中Netty异步架构的工作原理与应用 ... [详细]
  • Java集合框架特性详解与开发实践笔记
    Java集合框架特性详解与开发实践笔记 ... [详细]
  • ActiveMQ是由Apache开发的一款广受欢迎且功能强大的开源消息中间件。作为完全符合JMS 1.1和J2EE 1.4规范的JMS Provider实现,尽管JMS规范已问世多年,但ActiveMQ依然保持了其在消息队列领域的领先地位。本文将带你初步了解ActiveMQ的核心概念及其应用场景,帮助你快速入门这一重要的消息传递技术。 ... [详细]
  • .Net下RabbitMQ发布订阅模式实践
    一、概念AMQP,即AdvancedMessageQueuingProtocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。消息中间件主要用于组件之间的 ... [详细]
  • Java自学知乎!阿里高级算法专家公开10份资料,涨姿势!
    接口概述:接口是Java语言中的一种引用类型,是方法的集合,所以接口的内部主要就是定义方法,包含常量,抽象方法(JDK ... [详细]
  • rabbitmq集群搭建「建议收藏」
    rabbitmq集群搭建「建议收藏」一、基础安装前提:三个节点都主机映射,关防火墙网络,配好yum(后边出错,主机名和映射要对应)1.安装(三个节点)2.mq1启动rabbitmq ... [详细]
  • 深入解析Android 4.4中的Fence机制及其应用
    在Android 4.4中,Fence机制是处理缓冲区交换和同步问题的关键技术。该机制广泛应用于生产者-消费者模式中,确保了不同组件之间高效、安全的数据传输。通过深入解析Fence机制的工作原理和应用场景,本文探讨了其在系统性能优化和资源管理中的重要作用。 ... [详细]
  • 深入解析CAS机制:全面替代传统锁的底层原理与应用
    本文深入探讨了CAS(Compare-and-Swap)机制,分析了其作为传统锁的替代方案在并发控制中的优势与原理。CAS通过原子操作确保数据的一致性,避免了传统锁带来的性能瓶颈和死锁问题。文章详细解析了CAS的工作机制,并结合实际应用场景,展示了其在高并发环境下的高效性和可靠性。 ... [详细]
  • 在当今的软件开发领域,分布式技术已成为程序员不可或缺的核心技能之一,尤其在面试中更是考察的重点。无论是小微企业还是大型企业,掌握分布式技术对于提升工作效率和解决实际问题都至关重要。本周的Java架构师实战训练营中,我们深入探讨了Kafka这一高效的分布式消息系统,它不仅支持发布订阅模式,还能在高并发场景下保持高性能和高可靠性。通过实际案例和代码演练,学员们对Kafka的应用有了更加深刻的理解。 ... [详细]
  • 修复一个 Bug 竟耗时两天?真的有那么复杂吗?
    修复一个 Bug 竟然耗费了两天时间?这背后究竟隐藏着怎样的复杂性?本文将深入探讨这个看似简单的 Bug 为何会如此棘手,从代码层面剖析问题根源,并分享解决过程中遇到的技术挑战和心得。 ... [详细]
  • 优化后的标题:PHP分布式高并发秒杀系统设计与实现
    PHPSeckill是一个基于PHP、Lua和Redis构建的高效分布式秒杀系统。该项目利用php_apcu扩展优化性能,实现了高并发环境下的秒杀功能。系统设计充分考虑了分布式架构的可扩展性和稳定性,适用于大规模用户同时访问的场景。项目代码已开源,可在Gitee平台上获取。 ... [详细]
  • 在RabbitMQ中,消息发布者默认情况下不会接收到关于消息在Broker中状态的反馈,这可能导致消息丢失的问题。为了确保消息的可靠传输与投递,可以采用确认机制(如发布确认和事务模式)来验证消息是否成功抵达Broker,并采取相应的重试策略以提高系统的可靠性。此外,还可以配置消息持久化和镜像队列等高级功能,进一步增强消息的可靠性和高可用性。 ... [详细]
  • Windows下安装RaibbitMQ
    1.软件准备1.1erlang语言包到http:www.erlang.orgdownload.html下载,并且运行!安装目录C:\ProgramFil ... [详细]
author-avatar
huaxingwu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有