异步通讯-MQ

RabbitMQ安装

1、下载镜像

docker pull rabbitmq:3-management

2、安装MQ

执行下面的命令来运行MQ容器:

docker run \
 -e RABBITMQ_DEFAULT_USER=itcast \
 -e RABBITMQ_DEFAULT_PASS=123456 \
 --name mq \
 --hostname mq1 \
 -p 15672:15672 \
 -p 5672:5672 \
 -d \
 rabbitmq:3-management

RabbitMQ中的几个概念:

  • channel:操作MQ的工具
  • exchange:路由消息到队列中
  • queue:缓存消息
  • virtual host:虚拟主机,是对queue、exchange等资源的逻辑分组

MQ常见消息模型rabbitMQ官方网站

基本消息队列

基本消息队列的消息发送流程:
1.创建connection
2.创建channel(通道)
3.利用channel声明队列
4.利用channel向队列发送消息

基本消息队列的消息接收流程
1.创建connection
2.创建channel(通道)
3.利用channel声明队列
4.定义consumer的消费行为handleDelivery()
5.利用channel将消费者与队列绑定

SpringAMQP

  • AMQP是应用间消息通信的一种协议,与语言和平台无关

SpringAMQP如何发送消息-publisher

1、引入amqp的starter依赖

<!--AMQP依赖,包含RabbitMQ-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>

2、配置RabbitMQ地址

spring:
  rabbitmq:
    host: 192.168.2.128 #RabbitMQ的ip地址
    port: 5672 #端口
    username: itcast
    password: 123456
    virtual-host: / #虚拟主机

3、利用RabbitTemplate的convertAndSend方法

@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAMQPTest {
    @Autowired
    private RabbitTemplate rabbitTemplate;//使用rabbitTemplate发送消息
    @Test
    public  void testSendMessage2SimpleQueue(){
        String queueName="simple.queue";
        String message="hello springAmqp!";
        rabbitTemplate.convertAndSend(queueName,message);
    }

}

SpringAMQP如何接收消息-consumer编写消费逻辑,监听simple.queue

1、在consumer服务中编写application.yml,添加MQ连接信息:

spring:
  rabbitmq:
    host: 192.168.2.128 #RabbitMQ的ip地址
    port: 5672 #端口
    username: itcast
    password: 123456
    virtual-host: / #虚拟主机

2、在服务中新建一个类,编写消费逻辑:

@Component
public class SpringRabbitListener {
    @RabbitListener(queues="simple.queue")
    public void listenSimpleQueue(String msg){
        System.out.println("消费者接收到simple.queue的消息:【"+msg+"】");
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对接应用同步接口和MQ异步通讯的代码设计可以采用以下步骤: 1. 定义消息队列的生产者和消费者,生产者将消息发送到消息队列中,消费者从消息队列中获取消息并进行处理。 2. 在应用程序中,定义同步接口和异步通讯接口,同步接口直接调用业务逻辑处理,异步通讯接口将消息发送到消息队列中,由消费者进行处理。 3. 在同步接口中,可以使用消息队列的同步调用方式,将消息发送到消息队列中,等待消费者处理完成后返回结果。 4. 在异步通讯接口中,将消息发送到消息队列中,不需要等待消费者处理完成,可以立即返回结果。 5. 在消费者中,根据消息类型进行不同的业务处理,处理完成后将结果返回给生产者。 6. 在生产者中,根据消费者返回的结果,返回给调用方。 以下是一个简单的示例代码: ```python # 定义消息队列的生产者和消费者 class MQProducer: def send(self, message): # 将消息发送到消息队列中 pass class MQConsumer: def consume(self, message): # 根据消息类型进行不同的业务处理 pass # 定义同步接口和异步通讯接口 class SyncInterface: def handle(self, message): # 直接调用业务逻辑处理 pass class AsyncInterface: def handle(self, message): # 将消息发送到消息队列中 MQProducer.send(message) # 立即返回结果 return "success" # 在消费者中处理消息 class MQConsumer: def consume(self, message): if message.type == "sync": # 同步调用方式,等待消费者处理完成后返回结果 result = SyncInterface.handle(message) MQProducer.send(result) elif message.type == "async": # 异步通讯方式,不需要等待消费者处理完成 AsyncInterface.handle(message) # 在生产者中处理结果 class MQProducer: def send(self, message): MQConsumer.consume(message) # 根据消费者返回的结果,返回给调用方 return result ``` 注意:以上代码仅为示例,实际应用中需要根据具体情况进行修改和完善。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值