1 Feign介绍
- Feign是Spring Cloud提供的⼀个声明式的伪Http客户端, 它使得调⽤远程服务就像调⽤本地服务⼀样简单,只需要创建⼀个接口并添加⼀个注解即可;
- Nacos很好的兼容了Feign,Feign默认集成了 Ribbon, 所以在Nacos下使⽤Fegin默认就实现了负载均衡的效果;
2 订单微服务集成Feign
1.
在
shop-order-server
项⽬的
pom
⽂件加⼊
Fegin
的依赖
<!--fegin组件-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.
在启动类
OrderServer.java
上添加
Fegin
的扫描注解,
注意扫描路径
(
默认扫描当前包及其⼦包
)
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class OrderServer {
public static void main(String[] args) {
SpringApplication.run(OrderServer.class,args);
}
}
3.
在
shop-order-server
项⽬中新增接⼝
ProductFeignApi
package cn.wolfcode.feign;
/**
* name的名称⼀定要和订单服务的服务名保持⼀致
**/
@FeignClient(name = "product-service")
public interface ProductFeignApi {
@RequestMapping("/product/{pid}")
public Product findByPid(@PathVariable("pid") Long pid);
}
4.
修改
OrderServiceImpl.java
的远程调⽤⽅法
@Service
@Slf4j
public class OrderServiceImpl implements OrderService {
@Autowired
private OrderDao orderDao;
@Autowired
private ProductFeignApi productFeignApi;
@Override
public Order createOrder(Long productId, Long userId) {
log.info("接收到{}号商品的下单请求,接下来调⽤商品微服务查询此商品信息", productId);
//远程调⽤商品微服务,查询商品信息
Product product = productFeignApi.findByPid(productId);
log.info("查询到{}号商品的信息,内容是:{}", productId, JSON.toJSONString(product));
//创建订单并保存
Order order = new Order();
order.setUid(userId);
order.setUsername("叩丁狼教育");
order.setPid(productId);
order.setPname(product.getPname());
order.setPprice(product.getPprice());
order.setNumber(1);
orderDao.save(order);
log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));
return order;
}
}
5.
重启订单服务,并验证