前言
处于分布式系统下的服务间的调用是如何实现的?
一、feign是什么?
fegin旨在简化服务间的调用实现。实现了开发人员不在关注服务间的http请求的编写,只关注与自生的业务实现!
二、feign只有Java Http客户端变得更加容易这一个功能么?
并不是这样,fegin本身集成了ribbon实现了服务的负载均衡
三、为什么选择使用feign?
在feign没有之前我们如果实现服务间的调用会使用RestTemplate去实现服务间的调用。但是在实际开发中,有偶遇对于服务依赖的调用可能不止一处,往往一个借口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用。
所以,Feign在此基础上做了进一步封装,由他来帮助我们定义和实现依赖服务借口的定义。在Feign的实现下,我们只需创建一个接口并使用注解的方式来配置它,即可完成对服务提供方的接口绑定,并且feign集成了ribbon和restTemplate简化了使用Spring cloud Ribbon,自动封装服务调用客户端的开发量。并且实现了服务间的负载均衡。
可以看到feign的pom文件中引入了ribbon的jar所以feign可以帮助我们更加友好的实现服务间的调用以及负载均衡
而且feign基于resttemplate实现。resttemplate有的ClientHttpRequestFactory requestFactory有三种实现服务间的调用方式,分别是jdk的URLConnection,httpclient和okhttp
- SimpleClientHttpRequestFactory(封装URLConnection)
- HttpComponentsClientHttpRequestFactory(封装HttpClient)
- OkHttp3ClientHttpRequestFactory(封装OKHttp)
@Configuration
public class RestConfig {
@Bean
public RestTemplate restTemplate(){
RestTemplate restTemplate = new RestTemplate();
return restTemplate;
}
@Bean("urlConnection")
public RestTemplate urlConnectionRestTemplate(){
RestTemplate restTemplate = new RestTemplate(new SimpleClientHttpRequestFactory());
return restTemplate;
}
@Bean("httpClient")
public RestTemplate httpClientRestTemplate(){
RestTemplate restTemplate = new RestTemplate(new HttpComponentsClientHttpRequestFactory());
return restTemplate;
}
@Bean("OKHttp3")
public RestTemplate OKHttp3RestTemplate(){
RestTemplate restTemplate = new RestTemplate(new OkHttp3ClientHttpRequestFactory());
return restTemplate;
}
}
其实使用的时候一般都会只选择其中的一种,所以上面的几种配置任选其一,替换掉最上边那个就好。默认的是使用的jdk的SimpleClientHttpRequestFactory!!!
在feign中只需要导入对应的jar并激活
1.pom文件增加feign-httpclient的依赖(请注意与feign-core的版本保持一致)
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-httpclient</artifactId>
<version>9.4.0</version>
</dependency>
2.application.properties配置激活
feign.httpclient.enabled=true