springboot Rabbitmq 응답 메시지 직접 응답 모드를 구현하는 방법
1. 사용 시나리오
MQ의 기능에는 디커플링, 비동기 등이 포함됩니다.
일반적으로 생산자는 메시지 생성에만 책임이 있으며 누가 메시지를 받는지 또는 소비 결과가 무엇인지는 신경 쓰지 않습니다. 소비자는 비즈니스 처리를 위해 지정된 메시지를 받는 것만 책임지며 메시지가 어디서 왔는지 비즈니스에 응답하는지 신경 쓰지 않습니다. 처리 상태. 하지만 우리 프로젝트에는 특별한 비즈니스가 있습니다. 메시지 생성자로서 우리는 메시지를 생성한 후 소비자의 응답 결과를 받아야 합니다(직접 말하면 MQ에서 동기 호출 요청 응답을 사용하는 것과 비슷합니다). 연구를 통해 MQ의 응답 모드(직접 응답 모델)가 이 비즈니스 모델을 위해 만들어졌습니다.
2. 응답 실행
(1) 종속성 및 YML 구성
종속성:
rabbitMq
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency>
에 필요한 핵심 종속성만 나열합니다.
다른 특별한 구성은 없습니다. RabbitMQ의 대화형 방식
spring: rabbitmq: host: 10.50.40.116 port: 5673 username: admin password: admin
(2) RabbitMq 빈 구성
package com.leilei.demo; import org.springframework.amqp.core.FanoutExchange; import org.springframework.amqp.core.Queue; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; /** * @author lei * @create 2022-09-19 21:44 * @desc mq配置 **/ @Configuration public class RabbitMqConfig { @Bean public Queue bizQueue() { return new Queue("bizQueue"); } @Bean public Queue replyQueue() { return new Queue("replyQueue"); } @Bean FanoutExchange bizExchange() { return new FanoutExchange("bizExchange"); } }
비즈니스 클래스:
@Data @NoArgsConstructor @AllArgsConstructor public class Vehicle implements Serializable { private Integer id; private String name; }
(3) 메시지 생성 종료
메시지 생성 종료에서 해야 할 일: 메시지 생성 및 수락 Message 소비 응답
(1) 메시지 생성
1. 비즈니스 시나리오에 따라 메시지 생성, 전역적으로 고유한 사용자 지정 메시지 ID
2를 생성할지 여부를 선택합니다. (답장)
/** * 生产消息 * * @param * @return void * @author lei * @date 2022-09-19 21:59:18 */ public void replySend() { MessageProperties messageProperties = new MessageProperties(); messageProperties.setReplyTo("replyQueue"); //todo 根据业务,做一个严谨的全局唯一ID,我这里暂时用UUID String correlationId = UUID.randomUUID().toString(); // 我这里指定了唯一消息ID,看业务场景,消费者消费响应后,生产者端可根据消息ID做业务处理 messageProperties.setCorrelationId(correlationId); Vehicle vehicle = new Vehicle(1, "川A0001"); Message message = new Message(JSON.toJSONString(vehicle).getBytes(), messageProperties); rabbitTemplate.convertAndSend("bizExchange","",message); System.out.println("生产者发送消息,自定义消息ID为:" + correlationId); }
(2) 응답 응답 수락
소비자가 메시지를 소비한 후 처리 결과가 대기열로 전송됩니다. 이 대기열을 읽으면 해당 응답 결과를 얻을 수 있습니다. 비즈니스 처리를 위한 메시지
/** * 接收消息响应 * * @param message * @return void * @author lei * @date 2022-09-19 21:59:27 */ @RabbitListener(queues = "replyQueue") public void replyResponse(Message message) { String s = new String(message.getBody()); String correlationId = message.getMessageProperties().getCorrelationId(); System.out.println("收到客户端响应消息ID:" + correlationId); //todo 根据消息ID可判断这是哪一个消息的响应,我们就可做业务操作 System.out.println("收到客户端响应消息:" + s); }
(4) 메시지 소비자 측
메시지 소비자가 해야 할 일은: 메시지를 수락한 다음 비즈니스 처리를 수행하고 메시지에 응답하는 것입니다.
(1) 방법 1: sendTo 주석 + 메서드 반환 value
일반적으로 우리는 mq를 사용합니다. 리스너 메서드에는 반환 값이 필요하지 않습니다. 여기서는 sendTo 주석을 사용하며, 응답할 메시지는 반환 값으로 정의되어야 합니다. sendTo 주석은 응답할 대기열을 지정합니다. to
핵심 사항:
1. sendTo 주석은 해당 대기열을 지정합니다(생산 종료와 일치함)
2 메서드에서 정의한 반환 값 내용은 메시지입니다. 이는 결국 해당 대기열을 지정하기 위해 sendTo 주석으로 전송됩니다
3. 이 방법의 단점은 sendTo로 지정된 대상 대기열이 맹목적으로 작성될 수 있기 때문에 소비자 측이 매우 중요하다는 것입니다. 생산자 측에서 메시지 응답을 제대로 받지 못하는 현상이 발생하는데, 일반 프로젝트에서는 그렇지 않은 것 같아요
/** * 方式1 SendTo指定响应队列 * * @param message * @return String * @author lei * @date 2022-09-19 16:17:52 */ @RabbitListener(queues ="bizQueue") @SendTo("replyQueue") public String handleEmailMessage(Message message) { try { String msg=new String(message.getBody(), StandardCharsets.UTF_8); log.info("---consumer接收到消息----{}",msg); return "客户端响应消息:"+msg+"处理完成!"; } catch (Exception e) { log.error("处理业务消息失败",e); } return null; }
(2) 방법 2: 제작 측에서 메시지를 읽어보고 템플릿을 이용해 보내주세요
일반 소비자 메서드와 마찬가지로 비즈니스 대기열을 수신하려면 RabbitListener 주석만 필요하지만 메시지를 기반으로 ReplyTo 주소를 얻은 다음 자체 소비자 메서드 내에서 수동으로 메시지를 보내야 합니다.
1. 장점, 메시지 요청과 응답의 상호작용성을 더 강하게 느낄 수 있고, 프로세스가 더 명확해 보입니다
2. 단점, 코드가 세련되지 않습니다
/** * 方式2 message消息获取内部reply rabbitmq手动发送 * * @param message * @return String * @author lei * @date 2022-09-19 16:17:52 */ @RabbitListener(queues = "bizQueue") public void handleEmailMessage2(Message message) { try { String msg = new String(message.getBody(), StandardCharsets.UTF_8); log.info("---consumer接收到消息----{}", msg); String replyTo = message.getMessageProperties().getReplyTo(); System.out.println("接收到的reply:" + replyTo); rabbitTemplate.convertAndSend(replyTo, "客户端响应消息:" + msg + "处理完成!", x -> { x.getMessageProperties().setCorrelationId(message.getMessageProperties().getCorrelationId()); return x; }); } catch (Exception e) { log.error("处理业务消息失败",e); } }
(3) 방법 3: 메서드 반환 값
이 방법은 실제로는 1과 일치하지만, 생산자 메시지가 ReplyTo의 주소를 지정하기 때문에 소비자가 수동으로 메시지를 생성할 위치, 응답할지 여부, 위치를 다시 지정할 필요가 없습니다. 응답 메시지를 보내려면 생산 종료 자체가 비어 있고 소비자는 자체 비즈니스를 처리하고 결과만 반환하면 됩니다. 응답:
받은 응답:
링크:
위 내용은 springboot Rabbitmq 응답 메시지 직접 응답 모드를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











React 및 RabbitMQ를 사용하여 안정적인 메시징 애플리케이션을 구축하는 방법 소개: 최신 애플리케이션은 실시간 업데이트 및 데이터 동기화와 같은 기능을 달성하기 위해 안정적인 메시징을 지원해야 합니다. React는 사용자 인터페이스 구축을 위한 인기 있는 JavaScript 라이브러리인 반면 RabbitMQ는 안정적인 메시징 미들웨어입니다. 이 기사에서는 React와 RabbitMQ를 결합하여 안정적인 메시징 애플리케이션을 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. RabbitMQ 개요:

RabbitMQ를 사용하여 PHP에서 분산 메시지 처리를 구현하는 방법 소개: 대규모 애플리케이션 개발에서 분산 시스템은 일반적인 요구 사항이 되었습니다. 분산 메시지 처리는 작업을 여러 처리 노드에 분산하여 시스템의 효율성과 안정성을 향상시키는 패턴입니다. RabbitMQ는 AMQP 프로토콜을 사용하여 메시지 전달 및 처리를 구현하는 신뢰할 수 있는 오픈 소스 메시지 대기열 시스템입니다. 이 기사에서는 배포를 위해 PHP에서 RabbitMQ를 사용하는 방법을 다룹니다.

SpringBoot와 SpringMVC는 모두 Java 개발에서 일반적으로 사용되는 프레임워크이지만 둘 사이에는 몇 가지 분명한 차이점이 있습니다. 이 기사에서는 이 두 프레임워크의 기능과 용도를 살펴보고 차이점을 비교할 것입니다. 먼저 SpringBoot에 대해 알아봅시다. SpringBoot는 Spring 프레임워크를 기반으로 하는 애플리케이션의 생성 및 배포를 단순화하기 위해 Pivotal 팀에서 개발되었습니다. 독립 실행형 실행 파일을 구축하는 빠르고 가벼운 방법을 제공합니다.

최신 애플리케이션의 복잡성이 증가함에 따라 메시징은 강력한 도구가 되었습니다. 이 분야에서 RabbitMQ는 다양한 애플리케이션 간에 메시지를 전달하는 데 사용할 수 있는 매우 인기 있는 메시지 브로커가 되었습니다. 이 기사에서는 Go 언어에서 RabbitMQ를 사용하는 방법을 살펴보겠습니다. 이 가이드에서는 다음 내용을 다룹니다. RabbitMQ 소개 RabbitMQ 설치 RabbitMQ 기본 개념 Go에서 RabbitMQ 시작하기 RabbitMQ 및 Go

이 글에서는 dubbo+nacos+Spring Boot의 실제 개발에 대해 이야기하기 위해 자세한 예제를 작성하겠습니다. 이 기사에서는 이론적 지식을 너무 많이 다루지는 않지만 dubbo를 nacos와 통합하여 개발 환경을 신속하게 구축하는 방법을 설명하는 가장 간단한 예를 작성합니다.

Golang과 RabbitMQ 간의 실시간 데이터 동기화 솔루션 소개: 오늘날 인터넷의 대중화와 데이터 양의 폭발적인 증가로 인해 실시간 데이터 동기화가 점점 더 중요해지고 있습니다. 비동기 데이터 전송 및 데이터 동기화 문제를 해결하기 위해 많은 회사에서는 메시지 대기열을 사용하여 데이터의 실시간 동기화를 달성하기 시작했습니다. 이 글에서는 Golang과 RabbitMQ를 기반으로 한 실시간 데이터 동기화 솔루션을 소개하고 구체적인 코드 예시를 제공합니다. 1. RabbitMQ란 무엇인가요? 랍비

이제 점점 더 많은 회사들이 마이크로서비스 아키텍처 모델을 채택하기 시작하고 있으며 이 아키텍처에서 메시지 큐는 중요한 통신 방법이 되었으며 그 중 RabbitMQ가 널리 사용됩니다. Go 언어에서 go-zero는 최근 몇 년 동안 등장한 프레임워크로, 개발자가 메시지 대기열을 보다 쉽게 사용할 수 있도록 다양한 실용적인 도구와 방법을 제공합니다. 아래에서는 실제 응용 프로그램을 기반으로 한 go-zero를 소개합니다. RabbitMQ의 응용실습. 1.RabbitMQ 개요Rabbit

GolangRabbitMQ: 고가용성 메시지 대기열 시스템의 아키텍처 설계 및 구현에는 특정 코드 예제가 필요합니다. 소개: 인터넷 기술의 지속적인 발전과 광범위한 응용으로 인해 메시지 대기열은 현대 소프트웨어 시스템에서 없어서는 안될 부분이 되었습니다. 분리, 비동기 통신, 내결함성 처리 및 기타 기능을 구현하는 도구로서 메시지 큐는 분산 시스템에 대한 고가용성 및 확장성 지원을 제공합니다. 효율적이고 간결한 프로그래밍 언어인 Golang은 높은 동시성 및 고성능 시스템을 구축하는 데 널리 사용됩니다.
