推荐 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