SpringCloud实践专栏——远程微服务调用Feign

1. Feign实现服务间的调用

Feign的目的是简化java HTTP客户端开发的工具,Feign的初衷更加是为了降低统一绑定Denominator到HTTP API的复杂度,不区分是否为Restful

  • 那么,什么叫做服务之间的调用?

首先,这种情况是高度依赖于Eureka的,所以,我们需要将服务全部以客户端添加进Eureka中去进行注册。

然后比如说,我们有A微服务,B微服务,现在我们想在A的dao层创建一个接口,这个接口能直接使用到B微服务的Controller层的接口,这就叫做,跨Module调用接口。

2. 使用方法

首先我们将A服务的依赖进行注入(Eureka客户端配置可看上一篇文章)

		<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)
    public Result findById(@PathVariable("labelId") String labelId);

}

最后我们在入口文件中,加入注解,将Feign事件进行触发

@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient//发现Feign
@EnableFeignClients//触发

就可以了。

然后我们利用刚刚添加好的接口,进行一个简单的demo 调用

@RequestMapping(value = "/label/{labelId}", method = RequestMethod.GET)
	public Result findByLabelId(@PathVariable String labelId){
		Result result = baseClient.findById(labelId);
		return result;
	}

使用方法都是一样的。

那么,这样做有什么意义呢?

其实我觉得主要还是负载均衡,因为这些访问的时候都是依次去访问这些接口,所以贼稳。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值