使用springcloudstream操作rabbitmq


代码部分
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.java</groupId>
<artifactId>rabbitmq-springcloudstream</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>rabbitmq-springcloudstream</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR6</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.3.4.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-stream-binder-rabbit</artifactId>
</dependency>
</dependencies>
</project>

package com.java;
/**
* @Description:
* @Author: qiuxie
* @Create: 2023/7/21 12:22
*/
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.messaging.Sink;
import org.springframework.cloud.stream.messaging.Source;
@SpringBootApplication
@EnableBinding({Source.class, Sink.class})
public class SCApplication {
public static void main(String[] args) {
SpringApplication.run(SCApplication.class, args);
}
}
package com.java.consumer;
/**
* @Description:
* @Author: qiuxie
* @Create: 2023/7/21 12:25
*/
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.annotation.StreamListener;
import org.springframework.cloud.stream.messaging.Sink;
import org.springframework.stereotype.Component;
@Component
@EnableBinding(Sink.class)
public class MessageReceiver {
@StreamListener(Sink.INPUT)
public void process(Object message) {
System.out.println("received message : " + message);
}
}
package com.java.producer;
/**
* @Description:
* @Author: qiuxie
* @Create: 2023/7/21 12:24
*/
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.stream.messaging.Source;
import org.springframework.integration.support.MessageBuilder;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class SendMessageController {
@Autowired
private Source source;
@GetMapping("/sendfour")
public Object sendfour(String message) {
MessageBuilder<String> messageBuilder = MessageBuilder.withPayload(message).setHeader("routingkey","info");
source.output().send(messageBuilder.build());
return "message sended : "+message;
}
@GetMapping("/send1")
public Object send1(String message) {
MessageBuilder<String> messageBuilder = MessageBuilder.withPayload(message);
source.output().send(messageBuilder.build());
return "message sended : "+message;
}
@GetMapping("/sendBatch")
public Object sendbatch() {
for(int i = 0 ; i < 10 ; i ++) {
MessageBuilder<String> messageBuilder = MessageBuilder.withPayload("这是第"+i+"条消息");
source.output().send(messageBuilder.build());
}
return "message batch sended";
}
}
配置文件
one
#定义服务端rabbitmq地址 spring.rabbitmq.addresses=192.168.0.106:5672 spring.rabbitmq.username=root spring.rabbitmq.password=qwejkl1992 #定义虚拟机 #spring.rabbitmq.virtualHost=/mirror spring.cloud.stream.bindings.output.destination=qiuxieStream20230722 spring.cloud.stream.bindings.input.destination=qiuxieStream20230722 spring.cloud.stream.bindings.input.group=stream spring.cloud.stream.bindings.input.content-type=text/plain
two
#使用springcloudstream配置rabbitmq spring.cloud.stream.binders.qiuxie.type=rabbit spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.addresses=192.168.0.106 spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.port=5672 spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.username=root spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.password=qwejkl1992 spring.cloud.stream.bindings.output.destination=two spring.cloud.stream.bindings.input.destination=two spring.cloud.stream.bindings.input.group=stream spring.cloud.stream.bindings.input.content-type=text/plain
three
spring.cloud.stream.binders.qiuxie.type=rabbit spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.addresses=192.168.0.106 spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.port=5672 spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.username=root spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.password=qwejkl1992 #使用现有的交换机和队列 spring.cloud.stream.bindings.output.destination=fanoutExchange #指明交换机类型 spring.cloud.stream.rabbit.bindings.output.producer.exchange-type=fanout spring.cloud.stream.rabbit.bindings.output.producer.bind-queue=false spring.cloud.stream.bindings.input.destination=fanoutExchange #指明交换机类型 spring.cloud.stream.rabbit.bindings.input.producer.exchange-type=fanout spring.cloud.stream.bindings.input.group=fanout.q1 spring.cloud.stream.rabbit.bindings.input.consumer.bind-queue=false spring.cloud.stream.rabbit.bindings.input.consumer.queue-name-group-only=true spring.cloud.stream.bindings.input.content-type=text/plain
four
logging.level.com.java=debug logging.level.web=debug spring.devtools.add-properties=false spring.cloud.stream.binders.qiuxie.type=rabbit spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.addresses=192.168.0.106 spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.port=5672 spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.username=root spring.cloud.stream.binders.qiuxie.environment.spring.rabbitmq.password=qwejkl1992 #使用现有的交换机和队列 spring.cloud.stream.bindings.output.destination=directExchange #指明交换机类型 spring.cloud.stream.rabbit.bindings.output.producer.exchange-type=direct #为false表示使用已经有的交换机和队列,为true就会创建交换机和队列 spring.cloud.stream.rabbit.bindings.output.producer.bind-queue=false spring.cloud.stream.rabbit.bindings.output.producer.exchange-durable=false spring.cloud.stream.rabbit.bindings.output.producer.routing-key-expression=headers.routingkey spring.cloud.stream.bindings.input.destination=directExchange #指明交换机类型 spring.cloud.stream.rabbit.bindings.input.consumer.exchange-type=direct spring.cloud.stream.bindings.input.group=direct_queue #为false表示使用已经有的交换机和队列,为true就会创建交换机和队列 spring.cloud.stream.rabbit.bindings.input.consumer.bind-queue=false #为true表示交换机的名字只有direct_queue,没有destination spring.cloud.stream.rabbit.bindings.input.consumer.queue-name-group-only=true spring.cloud.stream.rabbit.bindings.input.consumer.exchange-durable=false spring.cloud.stream.rabbit.bindings.input.consumer.binding-routing-key=info spring.cloud.stream.bindings.input.content-type=text/plain
spring.profiles.active=one
浙公网安备 33010602011771号