ebFlux是Spring 5提供的响应式Web应用框架。
它是完全非阻塞的,可以在Netty,Undertow和Servlet 3.1+等非阻塞服务器上运行。
本文主要介绍WebFlux的使用。
FluxWeb vs noFluxWeb
WebFlux是完全非阻塞的。
在FluxWeb前,我们可以使用DeferredResult和AsyncRestTemplate等方式实现非阻塞的Web通信。
我们先来比较一下这两者。
注意:关于同步阻塞与异步非阻塞的性能差异,本文不再阐述。
阻塞即浪费。我们通过异步实现非阻塞。只有存在阻塞时,异步才能提高性能。如果不存在阻塞,使用异步反而可能由于线程调度等开销导致性能下降。
下面例子模拟一种业务场景。
订单服务提供接口查找订单信息,同时,该接口实现还需要调用仓库服务查询仓库信息,商品服务查询商品信息,并过滤,取前5个商品数据。
OrderService提供如下方法
public void getOrderByRest(DeferredResult<Order> rs, long orderId) { // [1] Order order = mockOrder(orderId); // [2] ListenableFuture<ResponseEntity<User>> userLister = asyncRestTemplate.getForEntity("http://user-service/user/mock/" + 1, User.class); ListenableFuture<ResponseEntity<List<Goods>>> goodsLister = asyncRestTemplate.exchange("http://goods-service/goods/mock/list?ids=" + StringUtils.join(order.getGoodsIds(), ",