From e8b95fd03f9b070172fcb5272c2ecf7a119307a7 Mon Sep 17 00:00:00 2001 From: YunaiV Date: Wed, 8 May 2019 23:40:09 +0800 Subject: [PATCH] =?UTF-8?q?-=20=E5=90=8E=E7=AB=AF=EF=BC=9ASearch=20?= =?UTF-8?q?=E6=A8=A1=E5=9D=97=EF=BC=8C=E5=BC=95=E7=94=A8=20Dubbo=20?= =?UTF-8?q?=E6=9C=8D=E5=8A=A1=E7=9A=84=E7=89=88=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../users/UsersProductSearchController.java | 2 +- .../biz/service/ProductSearchServiceImpl.java | 14 ++++++-------- .../src/main/resources/config/application.yaml | 10 ++++++++++ 3 files changed, 17 insertions(+), 9 deletions(-) diff --git a/search/search-application/src/main/java/cn/iocoder/mall/search/application/controller/users/UsersProductSearchController.java b/search/search-application/src/main/java/cn/iocoder/mall/search/application/controller/users/UsersProductSearchController.java index 8a74b5729..ab0bc2758 100644 --- a/search/search-application/src/main/java/cn/iocoder/mall/search/application/controller/users/UsersProductSearchController.java +++ b/search/search-application/src/main/java/cn/iocoder/mall/search/application/controller/users/UsersProductSearchController.java @@ -24,7 +24,7 @@ import static cn.iocoder.common.framework.vo.CommonResult.success; @Api("商品搜索") public class UsersProductSearchController { - @Reference(validation = "true") + @Reference(validation = "true", version = "${dubbo.provider.ProductSearchService.version}") private ProductSearchService productSearchService; @GetMapping("/page") // TODO 芋艿,后面把 BO 改成 VO diff --git a/search/search-service-impl/src/main/java/cn/iocoder/mall/search/biz/service/ProductSearchServiceImpl.java b/search/search-service-impl/src/main/java/cn/iocoder/mall/search/biz/service/ProductSearchServiceImpl.java index d9c212e18..1a787a8a2 100644 --- a/search/search-service-impl/src/main/java/cn/iocoder/mall/search/biz/service/ProductSearchServiceImpl.java +++ b/search/search-service-impl/src/main/java/cn/iocoder/mall/search/biz/service/ProductSearchServiceImpl.java @@ -2,7 +2,6 @@ package cn.iocoder.mall.search.biz.service; import cn.iocoder.common.framework.util.CollectionUtil; import cn.iocoder.common.framework.util.StringUtil; -import cn.iocoder.common.framework.vo.CommonResult; import cn.iocoder.common.framework.vo.SortingField; import cn.iocoder.mall.order.api.CartService; import cn.iocoder.mall.order.api.bo.CalcSkuPriceBO; @@ -37,7 +36,7 @@ import java.util.Map; import java.util.stream.Collectors; @Service -@org.apache.dubbo.config.annotation.Service(validation = "true") +@org.apache.dubbo.config.annotation.Service(validation = "true", version = "${dubbo.provider.ProductSearchService.version}") public class ProductSearchServiceImpl implements ProductSearchService { private static final Integer REBUILD_FETCH_PER_SIZE = 100; @@ -47,11 +46,11 @@ public class ProductSearchServiceImpl implements ProductSearchService { @Autowired private ElasticsearchTemplate elasticsearchTemplate; // 因为需要使用到聚合操作,只好引入 ElasticsearchTemplate 。 - @Reference(validation = "true") + @Reference(validation = "true", version = "${dubbo.consumer.ProductSpuService.version}") private ProductSpuService productSpuService; - @Reference(validation = "true") + @Reference(validation = "true", version = "${dubbo.consumer.ProductCategoryService.version}") private ProductCategoryService productCategoryService; - @Reference(validation = "true") + @Reference(validation = "true", version = "${dubbo.consumer.CartService.version}") private CartService cartService; @Override @@ -92,10 +91,9 @@ public class ProductSearchServiceImpl implements ProductSearchService { // 获得最小价格的 SKU ,用于下面的价格计算 ProductSpuDetailBO.Sku sku = spu.getSkus().stream().min(Comparator.comparing(ProductSpuDetailBO.Sku::getPrice)).get(); // 价格计算 - CommonResult calSkuPriceResult = cartService.calcSkuPrice(sku.getId()); - Assert.isTrue(calSkuPriceResult.isSuccess(), String.format("SKU(%d) 价格计算不会出错", sku.getId())); + CalcSkuPriceBO calSkuPriceResult = cartService.calcSkuPrice(sku.getId()); // 拼装结果 - return ProductSearchConvert.INSTANCE.convert(spu, calSkuPriceResult.getData()); + return ProductSearchConvert.INSTANCE.convert(spu, calSkuPriceResult); } @Override diff --git a/search/search-service-impl/src/main/resources/config/application.yaml b/search/search-service-impl/src/main/resources/config/application.yaml index 3ca895c2e..537878428 100644 --- a/search/search-service-impl/src/main/resources/config/application.yaml +++ b/search/search-service-impl/src/main/resources/config/application.yaml @@ -18,6 +18,16 @@ dubbo: name: dubbo scan: base-packages: cn.iocoder.mall.search.biz.service + provider: + ProductSearchService: + version: 1.0.0 + consumer: + ProductSpuService: + version: 1.0.0 + ProductCategoryService: + version: 1.0.0 + CartService: + version: 1.0.0 # rocketmq rocketmq: