2.RabbitMQ相关概念

介绍

RabbitMQ是一个消息中间件,接受并转发消息。它接收、存储和转发消息数据。

四大核心概念:

1.生产者

产生数据发送消息的程序是生产者。

2.消费者

3.队列

每一个队列对应一个消费者。

如果两个消费者对应同一个队列,那么队列中的消息只有一个消费者可以收到。

4.交换机

一个交换机可以对应多个队列。交换机与队列是绑定关系。

 六大模式

1.简单模式

2.工作模式

3.发布订阅模式

4.路由模式

5.主题模式

6.发布确认模式

RabbitMQ中名词解释

Broker表示接收和分发消息的应用,RabbitMQ Server就是Message Broker。

Exchange交换机

Queue队列

binding 绑定,交换机与队列之间的虚拟连接,binding包含routing key, binding信息被保存在exchange的查询表中,用于message的分发依据。

Producer生产者

Consumer消费者

Channel信道(发消息的通道)

Connection连接:生产者、消费者与broker之间的TCP连接。

每个Connection连接里可以有多个信道Channel。

为什么在Connection中会有多个channel信道:

建立TCP Connection是开销巨大的,效率也低下,Channel是在Connection内部建立逻辑连接Channel,如果应用程序支持多线程,通常每个thread创建单独的channel进行通信,channel之间是完全隔离的,channel作为轻量级Connection极大的减少了操作系统建立TCP Connection的开销。

Virtual host:出于多租户和安全因素设计,把amqp的基本组件划分到一个虚拟的分组中,类似于网络中的namespace概念。当多个不同的用户使用同一个RabbitMQ server的时候,可以划分多个vhost,每个用户在自己的vhost创建exchange/queue等。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: spring.rabbitmq.virtual-host是Spring Boot中RabbitMQ的虚拟主机配置属性。虚拟主机是RabbitMQ中的一个逻辑概念,它允许在一个物理主机上创建多个逻辑消息代理。每个虚拟主机都有自己的队列、交换机和绑定,它们之间是相互隔离的。在Spring Boot中,我们可以使用spring.rabbitmq.virtual-host属性来指定要使用的虚拟主机的名称。默认情况下,它的值为“/”,表示使用默认虚拟主机。如果我们需要使用其他虚拟主机,可以将其设置为相应的名称。 ### 回答2: 在RabbitMQ中,virtual-host(虚拟主机)是一种逻辑部分,可用于将不同的用户和应用程序分离。Spring AMQP提供了一个配置属性`spring.rabbitmq.virtual-host`来设置RabbitMQ虚拟主机。 首先,我们需要了解什么是虚拟主机。在RabbitMQ中,虚拟主机是一个RabbitMQ服务器中的逻辑部分,它类似于操作系统中的进程的概念,可以将不同的用户和应用程序分离,让它们彼此独立地运行。每个虚拟主机都具有自己的队列、交换机、绑定和权限控制机制,它们可以互不影响地存在于同一台物理机器上。通过使用虚拟主机,可以有效地隔离不同的应用程序,从而保证各应用程序之间的通信安全和可靠性。 在Spring AMQP中,我们可以通过设置`spring.rabbitmq.virtual-host`属性来配置RabbitMQ的虚拟主机。该属性默认值为`/`,表示使用默认的虚拟主机,也可以设置为其他虚拟主机名称。例如,我们可以使用以下配置来设置虚拟主机名称为`myVhost`: ``` spring.rabbitmq.virtual-host=myVhost ``` 配置好虚拟主机之后,我们可以使用`ConnectionFactory`来创建连接。`ConnectionFactory`类提供了一个`setVirtualHost()`方法,用于设置虚拟主机名称。例如: ```java @Configuration public class RabbitMQConfig { @Value("${spring.rabbitmq.host}") private String rabbitMQHost; @Value("${spring.rabbitmq.port}") private int rabbitMQPort; @Value("${spring.rabbitmq.username}") private String rabbitMQUsername; @Value("${spring.rabbitmq.password}") private String rabbitMQPassword; @Value("${spring.rabbitmq.virtual-host}") private String rabbitMQVirtualHost; @Bean public ConnectionFactory connectionFactory() { CachingConnectionFactory connectionFactory = new CachingConnectionFactory(rabbitMQHost, rabbitMQPort); connectionFactory.setUsername(rabbitMQUsername); connectionFactory.setPassword(rabbitMQPassword); connectionFactory.setVirtualHost(rabbitMQVirtualHost); return connectionFactory; } } ``` 在上面的示例中,我们创建了一个`ConnectionFactory` bean,并配置了连接RabbitMQ所需的所有属性,包括虚拟主机名称。然后,我们可以将这个bean注入到我们的其他组件中,如`RabbitTemplate`或`SimpleMessageListenerContainer`。 总的来说,`spring.rabbitmq.virtual-host`是一个非常重要的配置属性,它可以帮助我们有效地隔离不同的应用程序,从而提高整个系统的可靠性和安全性。在Spring AMQP中,通过配置该属性,我们可以轻松建立多个虚拟主机以满足不同的业务需求。 ### 回答3: 在RabbitMQ中,Virtual Host是一种逻辑概念,它允许多个独立的消息队列在同一个物理RabbitMQ服务器上运行,而不会互相影响。Virtual Host可以被看作是一个独立的RabbitMQ服务器,它有自己的用户、权限、交换机、队列和绑定,并且不同的Virtual Host之间是相互隔离的。 Spring AMQP框架提供了对RabbitMQ的完整整合,其中spring.rabbitmq.virtual-host属性是用来设置Virtual Host的。如果没有指定该属性,则默认为“/”,表示使用默认Virtual Host。可以根据实际需求设置不同的Virtual Host,以实现不同的业务应用之间的隔离与管理。 在Spring AMQP框架中,可以通过使用@RabbitListener和@RabbitHandler注解来监听指定Virtual Host下的队列,以便处理消息。同时,也可以使用RabbitTemplate来发送消息到指定的Virtual Host下的交换机和队列中。 总之,Virtual Host是RabbitMQ中实现隔离和管理的重要手段,而在Spring AMQP框架中,通过设置spring.rabbitmq.virtual-host属性可以轻松配置和管理Virtual Host。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卷土重来…

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值