Spring Webflux入门

18-10-30 banq
                   

Spring Boot现在采用了反应式编程(响应式Reactive),它是一种非阻塞的异步应用程序和事件驱动编程。Spring Framework在内部使用Reactor支持这种Reactive支持,Reactor是一个Reactive Streams实现,它进一步扩展了Publisher模型Flux和Mono。

让我们开始创建一个新的Spring Boot项目,将Webflux,Mongo Reactive和Lombok作为依赖项。

spring init --dependencies=webflux,data-mongodb-reactive,lombok --build=gradle --language=java reactive-webflux-workshop

现在让我们创建一个简单的POJO来存储和检索MongoDB中的信息:

@Data
@Document
@AllArgsConstructor
public class Person {

  @Id
  private String uuid;
  private String nickname;
  private String email;

}

Lombok的@Data注释生成getter和setter方法,toString(),equals(),hashcode()并为每个对象创建一个构造函数。

Spring Data现在支持MongoDB,Couchbase,Redis和Casandra的全面反应体验,在这种情况下,让我们创建一个PersonRepository实现ReactiveMongoRepository:

import org.springframework.data.mongodb.repository.ReactiveMongoRepository;
import reactor.core.publisher.Flux;
import com.jos.dem.webflux.model.Person;

public interface PersonRepository extends ReactiveMongoRepository<Person, String> {}

我们将CommandLineRunner用于启动我们的工作流程。这CommandLineRunner是Spring Boot中的回调接口,当Spring Boot启动时会传入args调用其run()方法 :

@SpringBootApplication
public class PersonApplication {

  public static void main(String[] args) {
    SpringApplication.run(PersonApplication.class, args);
  }

  @Bean
  CommandLineRunner start(){
    return args -> {
      System.out.println("Hello World!");
    };
  }

}

进一步定制start方法:创建人员列表并将其存储在MongoDB中:

@Bean
  CommandLineRunner start(PersonRepository personRepository){
    return args -> {
      Stream.of("josdem", "tgrip", "edzero", "skuarch", "siedrix")
      .map(nickname -> new Person(UUID.randomUUID().toString(), nickname, nickname + "@email.com"))
      .forEach(person -> personRepository.save(person).subscribe());
    };
  }

重要信息:在上面函数运算符中实现的逻辑仅在数据开始流动时执行,也就是直到使用subscribe()方法才会执行。

现在我们将Person对象存储到MongoDB,让我们添加一些代码来清理我们的数据库,插入和显示人员。

@Bean
  CommandLineRunner start(PersonRepository personRepository){
    return args -> {
      personRepository.deleteAll().subscribe();

      Stream.of("josdem", "tgrip", "edzero", "skuarch", "siedrix")
      .map(nickname -> new Person(UUID.randomUUID().toString(), nickname, nickname + "@email.com"))
      .forEach(person -> personRepository.save(person).subscribe());

      personRepository.findAll().log().subscribe(System.out::println);
    };
  }

为了运行这个例子,你需要在MongoDB中创建一个数据库authorization: "enabled"。另外,不要忘记将MongoDB凭据信息添加到您的application.properties文件中:

spring.data.mongodb.database=reactive_webflux

spring.data.mongodb.host=localhost

spring.data.mongodb.username=username

spring.data.mongodb.password=password

要浏览项目,请转到此处下载项目。