在提供服务的项目一方引入依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
然后在启动类中加入如下注解:
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients(basePackages = "com.cloud.product.client")
public class ProductServerApplication {
public static void main(String[] args) {
SpringApplication.run(ProductServerApplication.class, args);
}
}
其中,@EnableFeignClients该注解作用表明开启Feign功能,并扫描com.cloud.product.client包下的类,将其暴露为feign服务。
同样,在客户端项目中也引入相同依赖,加入相同注解,然后创建需要暴露服务的客户端类,如下所示:
@FeignClient(name = "product-server", fallback = ProductClient.ProductClientFallback.class)
public interface ProductClient {
@PostMapping("/product/listForOrder")
List<ProductInfoOutput> listForOrder(@RequestBody List<String> productIdList);
@PostMapping("/product/decreaseStock")
void decreaseStock(@RequestBody List<DecreaseStockInput> decreaseStockInputList);
@Component
static class ProductClientFallback implements ProductClient {
@Override
public List<ProductInfoOutput> listForOrder(List<String> productIdList) {
return null;
}
@Override
public void decreaseStock(List<DecreaseStockInput> decreaseStockInputList) {
}
}
}
其中,@FeignClient表明其是Feign服务的一个客户端,name的值为服务端在eureka上注册的名称,fallback的值对应的是当服务降级时触发的操作,这里可以先忽略该属性,后边讲Hystrix时会详细介绍。
当其他微服务调用该服务时,第一步添加依赖,
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
然后,引入Feign客户端的(product-client)依赖,
@Autowired
private ProductClient productClient;
最后直接使用该客户端的接口方法即可。