Feign是Netflix开发的声明式、模板化的HTTP客户端,其灵感来自Retrofit、JAXRS2.0以及WebSocket。
Feign可帮助我们更加便捷、优雅地调用HTTP API.
在Spring Cloud中,使用Feign非常简单——只需创建接口,并在接口上添加注解即可。
Feign支持多种注解,例如Feign自带的注解或者JAXRS注解等。Spring Cloud对Feign进行了增强,使其支持SpringMVC注解.
另外还整合了Ribbon和Eureka,从而使得Feign的使用更加方便.
前面的方式我们都是通过 Ribbon+RestTemplate 进行微服务调用 模式 , 那有什么弊端呢?
ResponseEntity<PayInfo> responseEntity = restTemplate.getForEntity(PAY_URI + orderInfo.getProductNo(), PayInfo.class);
#Ribbon调用
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
两个缺点:
采取开发中常用的套路 定义一个artisan-feign-api工程 ,用于单独管理和其他服务的接口。类似于DAO, COMMON这种模块
<dependency>
<groupId>org.springframework.cloudgroupId>
<artifactId>spring-cloud-starter-openfeignartifactId>
dependency>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
</plugin>
</plugins>
</build>
该工程式一个普通的jar 不需要打可执行的jar
@FeignClient(name = "artisan-product-center")
public interface ProductCenterFeignApi {
/**
* 声明式接口,远程调用http://artisan-product-center/selectProductInfoById/{productNo}
* @param productNo
* @return
*/
@RequestMapping("/selectProductInfoById/{productNo}")
ProductInfo selectProductInfoById(@PathVariable("productNo") String productNo);
}
这个声明式接口怎么写呢? --------- 直接把Controller接口 Copy过来即可。
<dependency>
<groupId>com.artisan</groupId>
<artifactId>artisan-feign-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
引入刚才的子模块,因为依赖是传递的,所以也相当于引用了feign ,这里仅引用子模块即可。
开启注解加入 @EnableFeignClients
同普通工程一样,无需改造
启动两个服务
artisan-cloud-feign-order artisan-cloud-feign-product
访问Order服务提供的接口