MQ组件之RabbitMQ学习

MQ组件之RabbitMQ入门

同步调用和异步调用

在微服务架构中,服务之间的调用有同步调用和异步调用两种方式。
我们使用OpenFeign去调用是同步调用,同步调用的缺点很明显,在下图的场景中,支付完成后需要调用订单服务、仓库服务、短信服务。没每调用一个服务耗时150ms,那么全部调用完成就需要450ms,如果后面还需要调用更多的服务,那么耗时会更久,而且如果后期需求变更,支付完成后还需要调用其它服务,那么还需要改代码。综上所述

  • 同步调用的优点:
    • 时效性较强,可以立即得到结果
  • 同步调用的缺点:
    • 耦合度高
    • 性能和吞吐能力下降
    • 有额外的资源消耗
    • 有级联失败问题
      在这里插入图片描述
      在这里插入图片描述

异步调用常见的实现是基于事件驱动的方式。
在这里插入图片描述

  • 异步调用的优点:
    • 耦合度低
    • 吞吐量提升
    • 故障隔离
    • 流量削峰
  • 异步调用的缺点:
    • 依赖于Broker的可靠性、安全性、吞吐能力
    • 架构复杂了,业务没有明显的流程线,不好追踪管理

什么是MQ

MQ (MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。

下图是常见MQ组件的对比。
在这里插入图片描述

RabbitMQ安装

这里使用的是docker镜像安装的方式。

  1. 首先把RabbitMQ镜像上传到虚拟机中,然后加载RabbitMQ镜像
 docker load -i /usr/local/mq.tar
  1. 启动RabbitMQ容器
docker run  -e RABBITMQ_DEFAULT_USER=root  -e RABBITMQ_DEFAULT_PASS=root  -v mq-plugins:/plugins  --name mq  --hostname mq  -p 15672:15672  -p 5672:5672  -d  rabbitmq:3-management

输入虚拟机的ip和开放的端口,即可访问RabbitMQ的管理后台:
在这里插入图片描述

RabbitMQ管理后台介绍

下图是RabbitMQ管理后台的预览页面,展示了RabbitMQ节点的相关信息,如节点的名字、状态、运行时间等
在这里插入图片描述

下图Connections(连接)页面,在这个页面查看、管理和关闭当前所有的TCP连接。
在这里插入图片描述

下图是Channels(通道)页面,这里展示了所有当前打开的通道以及它们的详细信息
在这里插入图片描述

下图是Exchanges(交换机)页面,这里可以查看、创建和删除交换机。交换机是RabbitMQ消息路由的重要组成部分,它决定了消息如何被路由到正确的队列。
在这里插入图片描述

下图是Queues(队列)页面,可以在这里看到所有的队列。队列是RabbitMQ的核心,它保存了所有待处理的消息。
在这里插入图片描述

下图是Admin(管理)页面,在这里可以管理RabbimtMQ的用户,并分配相关功能。为了给不同的用户授权不同的功能,RabbitMQ设计了一个virtual host(虚拟主机)的概念,每个用户只能看到它所在虚拟主机下的资源。virtual host是对queue、exchange等资源的逻辑分组。
在这里插入图片描述

下面是RabbitMQ官方关于如何监控RabbitMQ以及RabbitMQ管理后台的介绍。
如何监控RabbitMQ
RabbitMQ的管理插件介绍

RabbitMQ相关概念

下图是AMQP的通讯模型,由消息发送者、消息接收者、交换机、队列组成。

  • 消息发送者:发送消息
  • 消息接收者:消费消息
  • 交换机:路由消息,决定消息路由到哪个队列
  • 队列:负责存储消息
    在这里插入图片描述
    下图是RabbitMQ对于AMQP通讯模型的实现。
    在这里插入图片描述

RabbitMQ中常见的通讯模型主要可以分为两种,队列和发布/订阅,而这两种又可以往下细分。

  • 队列
    • 基本消息队列
    • 工作消息队列
  • 发布订阅,根据交换机类型不同可以分为三种
    • Fanout Exchange:广播
    • Direct Exchange:路由
    • Topic Exchange:主题

使用

下面介绍RabbitMQ中简单队列的使用。

消息发布者代码

public class Send {private static final String QUEUE_NAME = "hello";public static void send() {//建立和RabbitMQ Server的连接ConnectionFactory connectionFactory = new ConnectionFactory();connectionFactory.setHost("192.168.200.215");connectionFactory.setUsername("root");connectionFactory.setPassword("root");try (Connection connection = connectionFactory.newConnection()) {//创建通道Channel channel = connection.createChannel();channel.queueDeclare(QUEUE_NAME, false, false, false, null);String message = "Hello World1";//发送消息channel.basicPublish("", QUEUE_NAME, null, message.getBytes());} catch (IOException e) {e.printStackTrace();} catch (TimeoutException e) {e.printStackTrace();}}public static void main(String[] args) {send();}}

消息接收者代码

public class Recv {private static final String QUEUE_NAME = "hello";public static void receive() {ConnectionFactory factory = new ConnectionFactory();factory.setHost("192.168.200.215");factory.setUsername("root");factory.setPassword("root");try(Connection connection = factory.newConnection()) {Channel channel = connection.createChannel();//这里声明队列是因为,消费者有可能先启动,此时要确保有队列,才能尝试从队列中获取消息channel.queueDeclare(QUEUE_NAME, false, false, false, null);DeliverCallback callback = new DeliverCallback() {@Overridepublic void handle(String s, Delivery delivery) throws IOException {String message = new String(delivery.getBody(), "UTF-8");System.out.println("receive message: " + message);}};channel.basicConsume(QUEUE_NAME, true, callback, s -> {});} catch (IOException e) {e.printStackTrace();} catch (TimeoutException e) {e.printStackTrace();}}public static void main(String[] args) {receive();}}

消息发送成功后,可以在RabbitMQ管理后台中看到

在这里插入图片描述
通过下面的Get Message按钮可以获取未消费的消息
在这里插入图片描述

参考

  • RabbitMQ官方教程
  • rabbitMQ入门指南:管理页面全面指南及实战操作

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/762547.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【LeetCode-46.全排列】

题目详情: 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1: 输入:nums [1,2,3] 输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2: …

字符型数据详解

1 字符常量 C的字符常量是用单撇号括起来的一个字符。如a,x,D,?,$等都是字符常量。注意,a和A是不同的字符常量。 除了以上形式的字符常量外,C还允许用一种特殊形式的字符常量,就是以一个“\”开头的字符序列。例如,前面已经遇到过的,在printf函数中的…

DPDK and Trex环境指南

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、测试拓扑图 二、VirtualBox的网卡配置 三、DPDK支持的网卡 四、DPDK安装 1.DPDK向导 1). 英文向导 2). 中文向导 2.DPDK源码下载 3.DPDK源码解压 4.…

Linux的常用命令-1

ifconfig:看网络 ifconfig -a:看所以包括禁掉的网卡 ifconfig 网卡名 down:关网卡 ifconfig 网卡名 up:开网卡 ps -ef|grep 服务名:显示进程(ps -ef|grep sshd) kill -9 进程编号:杀进程 clear:清屏 exit:退出shell 切用户 …

今日问题:动态分配内存出错

2024.3.22 在搜素了许多文章和查阅了许多博客后依然没有找到问题所在&#xff0c;最后无意之间翻看以前的关于动态内存管理的代码后发现&#xff1a; 没加头文件&#xff1a;#include<stdlib.h> 苦笑不得了属于是 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio…

蓝桥杯day7刷题日记

P8697 [蓝桥杯 2019 国 C] 最长子序列 思路&#xff1a;直接遍历&#xff0c;和子序列相同就记录&#xff0c;不然就下一位 #include <iostream> #include <string> using namespace std; int res;int main() {string s,t;cin>>s>>t;int i0,j0;while…

关于msvcp140.dll丢失的解决方法详情介绍,修复dll文件的安全注意事项

在使用电脑的过程中&#xff0c;是否有遇到过关于msvcp140.dll丢失的问题&#xff0c;遇到这样的问题你是怎么解决的&#xff0c;都有哪些msvcp140.dll丢失的解决方法是能够完美解决msvcp140.dll丢失问题的&#xff0c;今天小编将带大家去了解msvcp140.dll文件以及分析完美解决…

代码随想录 Day-23

力扣题目 406.根据身高重建队列 思路 这里可以看出来是有两个维度考虑&#xff0c;和力扣题目 135.分发糖果&#xff08;可以看我day-22的文章&#xff09; 有点类似。 因此遇到这种两个维度权衡的时候&#xff0c;一定是先考虑一个维度再按照另一个维度来重新考虑排序。 两…

innodb 的 buffer pool 管理 page

page 页结构 page是整个InnoDB存储的最基本构件&#xff0c;也是InnoDB磁盘管理的最小单位&#xff0c;与数据库相关的所有内容都存储在这种Page结构里。 Page分为几种类型&#xff0c;常见的页类型有 数据页(Btree Node)Undo页(Undo Log Page)系统页(System Page)事务数据页 …

PC显示字体和浏览器的字体不一致

1&#xff1a;设置了PC的区域&#xff0c;显示字符&#xff0c; 2&#xff1a;导致浏览器显示的字符一半大一半小 3&#xff1a;为什么去设置这个&#xff0c;因为担心封号 4&#xff1a;不让它检测出我是他大佬

重要的数据模型之一Brand

重要的数据模型之一Brand 1. 创建class类2. 属性 2.1 属性name2.2 其他属性2.3 代码2.4 绘制牌2.5 添加属性2.6 重写绘制函数2.7 错误2.8 简单测试一下 3. 定义一个线程4. 修改5. 本次结束代码 重要的数据模型之一Brand 学习于bilibili 春娇与志明 1. 创建class类 在model包…

【C++初阶】第七站:string类的初识(万字详解、细节拉满)

前言&#xff1a; &#x1f4cd;本文知识点&#xff1a;string的初识 &#x1f4a8;个人博客:Dream_Chaser&#xff5e;-CSDN博客 &#x1f6a9;本专栏&#xff1a;C 目录 一、什么是STL 二、STL的六大组件 三、STL的缺陷 四、为什么学习string类&#xff1f; 五、标准库中…

云ERP vs 本地ERP:优劣对比与选择指南

在性能方面&#xff0c;本地ERP需要需要较高级别的计算机系统和其他设备来确保其高效运行。如果企业的计算机设备不够先进&#xff0c;那么选择本地ERP可能导致系统性能下降。而云ERP解决方案则能保证性能&#xff0c;只要企业拥有稳定的互联网连接即可。 在成本方面&#xff0…

Linux的基本使用

1.Linux的背景 1.1什么Linux Linux是⼀个操作系统.和Windows是"并列"的关系. 1.2Linux系统的优势 1. 开源(意味着免费,便宜) 2. 稳定(Linux可以运⾏很多年,都不会发⽣重⼤问题) 3. 安全(Linux只有管理员或者特定⽤⼾才能访问Linux内核) 4. ⾃由(不会被强加商业产品和…

练习题-15

问题&#xff1a;设函数 f ( x ) ∑ n 0 ∞ cos ⁡ ( n x ) 2 n f(x)\sum_{n 0}^{\infty} \frac{\cos (nx)}{2^n} f(x)∑n0∞​2ncos(nx)​. 求 A ∫ 0 2 π f 2 ( x ) d x A\int_0^{2\pi} f^2(x) dx A∫02π​f2(x)dx. 解&#xff1a;把 f f f看成是某个周期 2 π 2\pi 2…

EasyCloud软件简介

运行环境&#xff1a;Win10 PCL1.9 VTK8.1 Qt5.12 VS2017 基于PCL点云库的三维点云数据处理软件 1&#xff0e;软件用户界面 本软件的用户界面主要包括以下几个部分&#xff08;如图1&#xff09;&#xff1a; [1]菜单栏&#xff0c;将软件功能模块划分为不同菜单&…

JAVA八股--集合面试题

AVA八股--集合面试题--上 java只有值传递&#xff0c;没有引用传递代理模式Java之HashMap和Hashtable选用 ArrayDeque 来实现队列要比 LinkedList 更好为什么HashMap的长度一定是2的次幂&#xff1f;HashMap常见遍历方式 java只有值传递&#xff0c;没有引用传递 文章讲解 文…

第四讲 Buffer Pool

问题&#xff1a;DBMS 是如何管理其内存和磁盘之间来回移动数据的&#xff1f; 答案&#xff1a;在决定如何在磁盘中来回移动数据时&#xff0c;我们必须考虑两个关键方面&#xff1a; 空间控制【Spatial Control】&#xff1a; 将页【pages】写在在磁盘的什么地方&#xff…

HJ6 质数因子HJ7 取近似值HJ8 合并表记录HJ9 提取不重复的整数

HJ6 质数因子 质数因子_牛客题霸_牛客网 题目分析 算法的核心是质因数分解&#xff0c;它通过以下步骤实现&#xff1a; 1. 处理2的因子 首先&#xff0c;算法处理输入数n的2因子。因为2是最小的质数&#xff0c;也是唯一的偶数质数&#xff0c;所以首先检查n能被2整除多少…

vsc ctrl+. 无效的问题

描述 ubuntu ibus 输入法 vsc ctrl.快捷键无效 输出 _e 解决方案: 运行 ibus-setup 把表情符号这里的快捷键改了