SpringCloud——微服务调用Feign
1、Feign实现服务间调用
Feign是简化Java Http客户端开发的工具(java-to-httpclient-binder),它的灵感来自于Retrofit、JAXRS-2.0和WebSocket,Feign的初衷是降低统一绑定Denominator到Http API的复杂度,不区分是否为RESTFul。
那么话说回来什么叫做服务间的调用呢??
首先这种情况是高度依赖于Eureka的,因此需要将服务全部以客户端注册到Eureka中。 然后假设有两个微服务,现在想在一个的dao层创建一个接口,这个接口能直接使用到另外一个微服务的Controller层的接口这种情况就叫做跨模块调用接口。
2、使用方法
首先先添加Feign的依赖:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>2.0.1.RELEASE</version> </dependency>
然后在调用别的模块的微服务中创建接口,接口中需要使用@FeignClient去指定调用哪个模块的接口,这个引用的方式是使用另外一个被调用模块的application-name,然后将接口放过来即可。
@FeignClient("tensquare-base") public interface BaseClient { @RequestMapping(value = "/label/{labelId}", method = RequestMethod.GET) Result findById(@PathVariable("labelId") String labelId); }
然后修改启动类 然后在Controller层中进行调用
@Autowired private BaseClient baseClient; /** * 调用tensquare_base中的findById方法 */ @RequestMapping(value = "/label/{labelId}", method = RequestMethod.GET) public Result findByLabelID(@PathVariable("labelId") String labelId){ Result result = baseClient.findById(labelId); return result; }
Feign这样进行跨服务间的调用会依次的去调用,实现负载均衡。