您的位置:首页 > 编程语言 > Java开发

spring-cloud初体验(4.2)-服务调用-feign

2019-02-28 16:41 465 查看

上篇博客我们讲到了如何用restTemplate进行调用服务,这篇博客则讲一讲如何用feign调用的、

Feign简介

Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。

在Spring Cloud中,使用Feign非常简单——创建一个接口,并在接口上添加一些注解,代码就完成了。Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。

Spring Cloud对Feign进行了增强,使Feign支持了Spring MVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。

Spring Cloud Feign是基于Netflix feign实现,整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能外,还提供了一种声明式的Web服务客户端定义的方式。

Spring Cloud Feign帮助我们定义和实现依赖服务接口的定义。在Spring Cloud feign的实现下,只需要创建一个接口并用注解方式配置它,即可完成服务提供方的接口绑定,简化了在使用Spring Cloud Ribbon时自行封装服务调用客户端的开发量。

Spring Cloud Feign具备可插拔的注解支持,支持Feign注解、JAX-RS注解和Spring MVC的注解。

第一步,添加feign依赖

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
<version>1.4.0.RELEASE</version>
<classifier>sources</classifier>
<type>java-source</type>
</dependency>

第二部,启动主类添加注解

第三步,新建接口

第四步,调用接口成功

此外,feign默认负载均衡策略是轮询,支持自定义,意思是,比如一个电商项目,你的订单服务是一个集群,部署了多个注册在了eureka注册中心,,那么feign默认是轮询的方式在集群中获取一个服务进行调用

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: