SpringCloud-Stream的搭建和配置使用

以下相关的项目配置请到gitee查看https://gitee.com/xwb1056481167/spring-cloud

什么是SpringCloudStream

官网定义Spring cloud Stream是一个构建消息驱动微服务的框架 应用程序通过inputs和outputs来与SpringCloud Stream中binder对象交互 通过我们配置来binding(绑定)而SpringCloudStream的binder对象 负责与消息中间件交互。 所以,我们只需要搞清楚如何与SpringCloudStream交互就可以方便的使用消息驱动的方式。

为什么要引入

通过使用Spring Integration来连接消息代理中间件以实现消息驱动事件驱动, Spring Cloud Stream为一些供应商的消息中间件产品提供了个性化的自动化配置实现, 应用了发布-订阅、消费组、分区的三个核心概念。 仅支持RabbitMQ、Kafka 中文帮助手册

https://m.wang1314.com/doc/webapp/topic/20971999.html

springCloudStream标准流程

组件

说明

Middleware

中间件,目前只支持RabbitMQ、Kafka

Binder

Binder是应用于消息中间件之间的封装,目前实行了kafka和RabbitMQ的Binder,通过Binder可以很方便的链接中间件,可以动态的改变消息类型(对应kafka的topic和RabbitMQ的exchange),这些都可以通过配置文件来实现

@Input

注解表示输入通道,通过该输入通道接受到的消息进入应用程序

@Output

表示注解输出通道,发布的消息将通过该通道离开应用程序

@StreamListener

监听队列,用于消费者的队列的消息接收

@EnableBinding

指信道channel和exchange绑定在一起

消费者、提供者的集成

消息提供者cloud-stream-rabbitmq-provider8801

1、pom.xml

<!-- stream rabbitmq -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
</dependency>
<!-- 添加rabbitmq的支持 -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

2、yml的核心配置

spring:
  cloud:
    stream:
      binders: #在此处配合要绑定的rabbitmq的服务信息
        defaultRabbit: #表示定义的名称,用于binding整合
          type: rabbit #消息组件类型
          environment: #设置rabbitmq的相关环境配置
            spring:
              rabbitmq:
                host: localhost
                port: 5672
                username: guest
                password: guest
      bindings: #服务的整合处理
        output: #这个名字是一个通道的名字
          destination: studyExchange #表示要使用的Exchange你名称定义
          content-type: application/json #设置消息类型,本次为json,文本则为"text/plain"
          binder: defaultRabbit #设置要绑定的额消息服务的具体设置

3、主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class StreamMQMain8801 {
    public static void main(String[] args) {
        SpringApplication.run(StreamMQMain8801.class,args);
    }
}

4、核心配置发送者

// 1、接口
public interface IMessageProvider {
    public String send();
}
//2、接口实现类
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.messaging.Source;
import org.springframework.messaging.MessageChannel;
import org.springframework.messaging.support.MessageBuilder;
import org.xwb.springcloud.service.IMessageProvider;
import javax.annotation.Resource;
import java.util.UUID;
/**
 * 定义消息的推送管道
 * 里面注入的内容都是message的,谨记不是注入dao、或其他什么,
 */
@EnableBinding(Source.class)
public class IMessageProviderImpl implements IMessageProvider {
    @Resource
    private MessageChannel output;
    @Override
    public String send() {
        String serial = UUID.randomUUID().toString();
        output.send(MessageBuilder.withPayload(serial).build());
        System.out.println("****************serial:"+serial);
        return serial;

    }
}
//3、controller发送
@RestController
public class SendMessageController {
    @Resource
    private IMessageProvider messageProvider;
    @GetMapping("/sendMessage")
    public String sendMessage() {
        return messageProvider.send();
    }
}

注意:@EnableBindingMessageChannel的jar包引入,都是cloud.stream.*的依赖

消息消费者8802,8803

8002和8003的配置一样,只有端口号不一样,此处指配置8002.8003下同
新建模块cloud-stream-rabbitmq-consumer8802

1、pom.xml

 <!-- stream rabbitmq -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
</dependency>
<!-- 添加rabbitmq的支持 -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

2、yml配置

spring:
  cloud:
    stream:
      binders: #在此处配合要绑定的rabbitmq的服务信息
        defaultRabbit: #表示定义的名称,用于binding整合
          type: rabbit #消息组件类型
          environment: #设置rabbitmq的相关环境配置
            spring:
              rabbitmq:
                host: localhost
                port: 5672
                username: guest
                password: guest
      bindings: #服务的整合处理
        input: #这个名字是一个通道的名字
          destination: studyExchange #表示要使用的Exchange你名称定义
          content-type: application/json #设置消息类型,本次为json,文本则为"text/plain"
          binder: defaultRabbit #设置要绑定的额消息服务的具体设置

注意:bindings.input。此处是消费者需要从通道拿到消息,输入到sink中读取。
3、主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class StreamMQMain8802 {
    public static void main(String[] args) {
        SpringApplication.run(StreamMQMain8802.class, args);
    }
}

4、消息的接收消费

@Component
@EnableBinding(Sink.class)
public class ReceiveMessageListenerController {
    @Value("\${server.port}")
    private String serverPort;
    @StreamListener(Sink.INPUT)
    public void receiveMessage(@Payload String in, @Header(AmqpHeaders.CONSUMER_QUEUE) String queue) {
        System.out.println("消费者"+serverPort+"收到的消息为-->:"+in + " received from queue " + queue);
    }
}

注意:@EnableBindingMessageChannel的jar包引入,都是cloud.stream.*的依赖
依照8002创建8003项目。

测试

启动7001,8801生产者,8002、8003消费者,地址栏输入get请求发送消息

http://localhost:8801/sendMessage

rabbitmq的峰值变化

8802和8803的接收消息结果

分组消费与持久化

问题:8801发送的消息,8802,8803都会去消费,如何去解决
原理:微服务应用放置于同一个group中,就能够保证消息只会被其中一个应用消费一次,
不同的组是可以次奥非得,同一个组会发生竞争关系,只有其中一个可以消费。

分组

1、所以解决办法是将他们分到同一个组中即可

spring:
  application:
    name: cloud-stream-customer #服务名
  cloud:
    stream:
      binders: #在此处配合要绑定的rabbitmq的服务信息
        defaultRabbit: #表示定义的名称,用于binding整合
          type: rabbit #消息组件类型
          environment: #设置rabbitmq的相关环境配置
            spring:
              rabbitmq:
                host: localhost
                port: 5672
                username: guest
                password: guest
      bindings: #服务的整合处理
        input: #这个名字是一个通道的名字
          destination: studyExchange #表示要使用的Exchange你名称定义
          content-type: application/json #设置消息类型,本次为json,文本则为"text/plain"
          binder: defaultRabbit #设置要绑定的额消息服务的具体设置
          group: consumerA

加入到同一个组中:group: consumerA即可避免重复消费

持久化

如果8802,8803有一个配置了分组,另外一个取消了,配置了分组的那个消费者在消费者重启后会自动去消费8801发送者发送的消息。使消息持久化。
证明: 一定要配置group

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 我可以提供一些有关使用Java和Spring Cloud开发电商项目的建议:1.使用Spring Boot搭建你的应用程序,这将极大地简化你的开发过程;2.使用Spring Cloud Netflix来构建你的微服务架构;3.将Spring Data JPA与你的数据库集成,来实现持久化操作;4.使用Spring Cloud Config来实现配置管理;5.使用Spring Security来实现安全认证;6.使用Spring Cloud Netflix Eureka来实现服务注册与发现;7.使用Spring Cloud Netflix Zuul来实现API网关;8.使用Spring Cloud Bus来实现消息总线;9.使用Spring Cloud Stream来实现消息驱动的微服务。 ### 回答2: 使用Java和Spring Cloud开发电商项目可以带来许多好处。Java是一种强大的编程语言,具有良好的跨平台性和丰富的开发工具和框架。而Spring Cloud是一个基于Spring框架的开发工具,它提供了一套方便的微服务组件,可以快速构建分布式系统。 使用Java和Spring Cloud开发电商项目,首先可以利用Java的面向对象特性来设计和开发项目的各个模块,使得代码结构清晰、可维护性强。同时,Java的丰富的库和框架可以提供很多功能模块的实现,例如数据库操作、网络通信、数据加密等,大大缩短了开发周期。 而Spring Cloud作为一个微服务框架,可以提供服务注册与发现、负载均衡、断路器、配置中心等解决方案,可以帮助开发者更轻松地实现分布式系统的各个模块。例如,使用Spring Cloud Eureka进行服务注册与发现,可以方便地管理服务之间的依赖关系,并提供自动负载均衡;使用Spring Cloud Config可以集中管理各个服务的配置信息,方便维护和修改。 在电商项目中,Java和Spring Cloud可以帮助我们实现用户管理、商品管理、订单管理等核心功能。我们可以使用Spring Cloud提供的服务注册与发现功能,将用户服务、商品服务、订单服务等拆分为独立的Spring Boot项目,并使用Feign或RestTemplate实现服务间的调用。这样,我们可以方便地扩展和修改各个模块,提高系统的可扩展性和可维护性。 总之,使用Java和Spring Cloud来开发电商项目是一个可行的选择。Java的强大和Spring Cloud的丰富功能可以帮助我们快速构建分布式系统,并能够方便地扩展和修改各个功能模块,提高开发效率和项目质量。 ### 回答3: 使用Java和Spring Cloud开发一个电商项目可以提供一个高效、可靠的电子商务平台。Java是一种范式化的、面向对象的、编译和解释执行的高级编程语言,它的特点是安全、稳定、可移植性强。而Spring Cloud是一个基于Spring Boot的开发工具箱,它提供了一整套微服务架构的解决方案,包括服务注册与发现、负载均衡、服务容错保护等。 在电商项目中,Java和Spring Cloud的结合可以实现以下功能: 1. 用户认证与授权:可以使用Java中的安全框架和Spring Cloud的微服务架构,实现用户登录、注册、密码加密、授权等功能。 2. 商品管理:可以使用Java的面向对象特性和Spring Cloud的分布式架构,实现商品的增删改查、库存管理、图片上传等功能。 3. 订单管理:可以使用Java的多线程处理和Spring Cloud的分布式事务管理,实现订单的创建、支付、取消等功能。 4. 评论与评分:可以使用Java中的数据库访问技术和Spring Cloud的消息队列,实现用户对商品的评论、评分等功能。 5. 支付与物流:可以使用Java的支付接口和Spring Cloud的服务调用功能,实现用户的在线支付和物流信息查询等功能。 6. 数据统计与分析:可以使用Java的数据处理和Spring Cloud的日志监控功能,实现销售数据的实时统计和分析报表的生成。 总之,使用Java和Spring Cloud开发电商项目可以充分发挥Java的稳定性和可移植性,以及Spring Cloud的微服务架构和分布式系统的优势,实现一个高效、可靠的电子商务平台。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值