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 {}
我们将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
要浏览项目,请转到此处下载项目。