Spring Cloud系列教程 | 第十五篇:Spring WebFlux和Spring Cloud的反应式微服务

推荐 Spring Boot/Cloud 视频:

我已经在一年前的文章Reactive microservices with Spring 5中描述了Spring反应支持。当时Spring WebFlux项目一直在积极开发中,现在在Spring 5正式发布之后,值得看看它的当前版本。此外,我们将尝试将我们的反应式微服务置于Spring Cloud生态系统中,其中包含诸如Eureka服务发现,Spring Cloud Commons负载平衡@LoadBalanced以及使用Spring Cloud Gateway(也基于WebFlux和Netty)的API网关等元素。我们还将通过示例来检查Spring对NoSQL数据库的反应支持Spring Data Reactive Mongo项目。

这是一个图,说明了我们的示例系统的体系结构,包括两个微服务,发现服务器,网关和MongoDB数据库。源代码在 spring-cloud-webflux-exampleGitHub上提供。

在这里插入图片描述
让我们描述创建上述系统的方法的进一步步骤。

步骤1.使用Spring WebFlux构建响应式应用程序

要为项目启用库Spring WebFlux,我们应该spring-boot-starter-webflux在依赖项中包含starter 。它包括一些依赖库,如Reactor或Netty服务器。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-webflux</artifactId>
</dependency>


REST控制器看起来非常类似于为同步Web服务定义的控制器。唯一的区别在于返回对象的类型。而不是单个对象,我们返回类的实例Mono,而不是列表,我们返回类的实例Flux。感谢Spring Data Reactive Mongo,我们不必再在存储库bean上调用所需的方法。

@RestController
public class AccountController {
 
    private static final Logger LOGGER = LoggerFactory.getLogger(AccountController.class);
 
    @Autowired
    private AccountRepository repository;
 
    @GetMapping("/customer/{customer}")
    public Flux findByCustomer(@PathVariable("customer") String customerId) {
        LOGGER.info("findByCustomer: customerId={}", customerId);
        return repository.findByCustomerId(customerId);
    }
 
    @GetMapping
    public Flux findAll() {
        LOGGER.info("findAll");
        return repository.findAll();
    }
 
    @GetMapping("/{id}")
    public Mono findById(@PathVariable("id") String id) {
        LOGGER.info("findById: id={}", id);
        return rep
  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值