Docker安装RabbitMQ AMQP协议及重要角色

 更新时间:2023年05月10日 10:25:33   作者:stark张宇  
这篇文章主要为大家介绍了Docker安装RabbitMQ AMQP协议和主要角色详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

概述

不管是微服务还是分布式的系统架构中,消息队列中间件都是不可缺少的一个重要环节,主流的消息队列中间件有RabbitMQ、RocketMQ等等,从这篇开始详细介绍以RabbitMQ为代表的消息队列中间件。

AMQP协议

  • AMQP协议是一个提供统一消息服务的应用层标准协议,基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。
  • AMQP协议是一种二进制协议,提供客户端应用与消息中间件之间的异步、安全、高效的交互。
  • AMQP作为中间层服务,把消息生产和消费分隔开来,当消费者产生出现异常,不影响消费者对消息的消费,当消费者异常时,生产者生产的消息可以存放到服务的内存或者磁盘,不会影响想消费的速率,同时,消息也可以基于路由的规则可以投递到指定的消费者消费。

AMQP协议重要角色

1.生产者和消费者

  • 生产者是生产消息的主体,消费者是消费消息的主体
  • 数据集成与系统解耦、异步处理与事件驱动、流量薛峰、事务消息与分布式事务的最终一致
  • 生产者生产一条消息丢给消息代理,消息代理根据投递规则将消息传到消费者手上

2.交换机

  • 交换机就像是消息代理的路由器,负责拿到一个消息之后,根据确定的规则(路由键)将它路由给一个或零个队列,交换机具备多种路由模式。
  • 基于消息生产者和路由规则可以将消息投递到指定的Message Queue,交换机收到生产者投递的消息,基于路由规则及队列绑定关系匹配到投递对应的交换机或者队列进行分发,交换机不存储消息,只做转发

交换机类型:

  • 直连交换机:根据路由键完全匹配的投递到对应的队列
  • 扇形交换机:无视路由键,将消息进行拷贝,并路由到给绑定到它身上所有队列,提供了一个广播的效果。
  • 主题交换机:根据路由键按模式匹配的投递到对应的队列
  • 交换机也具备自己的属性,可以定义自己的名字,是否持久化等选项。

3.队列

  • 队列是消息的暂存地,至少有一个消费者订阅了队列的话,消息会立即发送给这些订阅的消费者,但是如果消息到达了无人的订阅队列,消息会在队列中等待,等待有了消费者便进行分发。
  • Exchange和Message Queue之间存在绑定关系,消息到了Exchange 后基于路由策略可以将消息投递到已绑定且符合路由策略的Message Queue。
  • 消息队列会将消息存储到内存或者是磁盘中,并将这些消息按照一定顺序转发给一个或多个消费者,每个消息队列都是独立隔离的,相互不影响。
  • 消息队列具有不同的属性(私有、共享、持久化、临时、客户端定义或者服务端定义等)),可以基于实际需求选择对应的类型

4.消息

  • 消息是信息的载体,也是AMQP协议的一个实体,消息包含两部分
  • 载荷:就是真正的信息,是你想要传输的任何内容,该部分内容对消息代理来说是透明的
  • 元信息:包含路由键、内容类型、编码、是否持久化等消息属性,会被消息代理所解析,消息代理根据消息的属性对这条消息进行投递,存储等,这部分被消息代理所关系,而消费者对其是不关心的。

5.信道

  • 网络信道,是建立在Connection链接之上的一种轻量级的链接,几乎所有的操作都在Channel中进行,Channel是进行消息读写的通道,客户端可以建立对各Channel,每个Channel代表一个会话任务。
  • 一个Connection上可以创建任意数量的Channel

Docker安装RabbitMQ

1.查看Docker仓库里的RabbitMQ镜像

# 查询镜像
docker search rabbitmq
# 下载镜像
docker pull rabbitmq

2.启动MQ安装management

如果在云服务上部署需在安全组开通一下端口:15672(UI页面通信口)、5672(client端通信口)、25672(server间内部通信口)、61613(stomp 消息传输)、1883(MQTT消息队列遥测传输)。

docker run -d --name rabbit -e \
RABBITMQ_DEFAULT_USER=stark -e RABBITMQ_DEFAULT_PASS=1990@stark 
-p 15672:15672 \
-p 5672:5672 \
-p 25672:25672 \
-p 61613:61613 \
-p 1883:1883 rabbitmq:management

使用 http://127.0.0.1:15672访问,账号和密码就是参数RABBITMQ_DEFAULT_USERRABBITMQ_DEFAULT_PASS设置的值。

以上就是 Docker安装RabbitMQ、AMQP协议、和主要角色的详细内容,更多关于 Docker安装RabbitMQ的资料请关注脚本之家其它相关文章!

相关文章

  • docker中的环境变量使用与常见问题解决方案

    docker中的环境变量使用与常见问题解决方案

    这篇文章主要给大家介绍了关于docker中环境变量使用与常见问题解决方案的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用docker具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • 使用Docker部署Tomcat的实现示例

    使用Docker部署Tomcat的实现示例

    在本地编写好了Spring项目,为了实现能够随时地访问,所以需要将项目部署到服务器,本文主要介绍了使用Docker部署Tomcat的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • Docker镜像优化打包速度思考

    Docker镜像优化打包速度思考

    本文主要介绍了Docker镜像优化打包速度思考,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • 详解Docker挂载本地目录

    详解Docker挂载本地目录

    这篇文章主要介绍了详解Docker挂载本地目录,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Ubuntu 20.04 上安装和使用 Docker的详细过程(安装包)

    Ubuntu 20.04 上安装和使用 Docker的详细过程(安装包)

    这篇文章主要介绍了Ubuntu 20.04 上安装和使用 Docker的详细过程(安装包),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • docker-compose搭建mongodb、mysql的详细过程

    docker-compose搭建mongodb、mysql的详细过程

    这篇文章主要介绍了docker-compose搭建mongodb、mysql的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • Docker拉镜像报错error pulling image configuration: unknown blob

    Docker拉镜像报错error pulling image configuration:

    这篇文章主要介绍了Docker拉镜像报错error pulling image configuration: unknown blob的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • 如何隔离docker容器中的用户的方法

    如何隔离docker容器中的用户的方法

    这篇文章主要介绍了如何隔离docker容器中的用户的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • Docker容器不识别宋体等字体的解决方案

    Docker容器不识别宋体等字体的解决方案

    这篇文章主要介绍了Docker容器不识别宋体等字体的解决方案,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • 3分钟用Docker搭建一个Minecraft服务器

    3分钟用Docker搭建一个Minecraft服务器

    这篇文章主要介绍了3分钟用Docker搭建一个Minecraft服务器的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2016-11-11

最新评论