我们就之前的例子,现在来改良一下。
一、订单模块修改
因为我们订单模块是需要调用商品模块,所以我们需要在订单模块中引入 OpenFeign 的支持(商品模块中不需要~~~)
pom
<!-- openFeign -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
首先引入 OpenFeign 的支持。
yml
spring:
application:
name: microservice-order
yml 中我们增加一个 spring.application.name,因为 OpenFeign 是通过这个应用名称来进行调用服务的,虽然订单模块不是被调用的,但是我们要做到规范,这里也写上~
创建 Feign 接口
因为 Feign 是一个声明式服务调用,所以我们需要创建一个接口,到时候直接在订单模块中调用直接调用我们的 Feign 接口即可。
这个接口的样子最好是和我们之前调用的 Controller 中的接口样子一样(比如说请求类型,参数类型,方法名称等)
光定义成这样还不够,我们还需要一个注解支持:@FeignClient
这个注解可以指定我们要调用那个服务,完整代码如下:
@FeignClient(name = "microservice-commodity")
public interface CommodityOpenFeignService {
@GetMapping("/commodity/getCommodityPrice/{id}")
BigDecimal getCommodityPrice(@PathVariable(value = "id") String id);
}
name 后面就是写的服务的名称,也就是一会我们要配置在商品模块的 spring.application.name
启动类
我们在订单模块的启动类上增加 Spring 对 OpenFeign 的支持
@EnableFeignClients
然后将启动类中之前创建的 RestTemplate Bean 注释掉或者删除掉。
业务代码修改
因为我们将 RestTemplate 已经删掉了,所以 Controller 中引入的 RestTemplate 也可以删掉了。
接着我们引入刚刚定义好的 Feign 接口,然后我们来看一下核心代码的修改
...
// TODO 这里需要去查询商品的价格,然后乘以数量,得到价钱。
// BigDecimal price = restTemplate.getForObject("http://localhost:1000/commodity/getCommodityPrice/" + commodityId, BigDecimal.class);
BigDecimal price = commodityOpenFeignService.getCommodityPrice(commodityId);
...
二、商品模块修改
商品模块修改很简单,我们就加一个 spring.application.name 即可
spring:
application:
name: microservice-commodity
这里的 name 要和订单模块 FeignClient 中的 name 相同!!!
三、测试
启动 Eureka Server 集群,再启动两个服务。
可以看到,当前服务是可以使用的,我们再来看一下数据库
同样,数据库中也是有值的。
这一讲就讲到这里,有问题可以联系我:QQ 2100363119,欢迎大家访问我的个人网站:https://www.lemon1234.com
最近网站已经做好,并且已经上线,欢迎各位留言~~