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这样进行跨服务间的调用会依次的去调用,实现负载均衡。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值