一、什么是Feign
Feign是Spring Cloud Netflix组件中的一个轻量级RESTful的HTTP服务客户端,实现了负载均衡和rest调用的开源框架,封装了Ribbon和RestTemplate,实现了WebService的面向接口编程,进一步降低了项目的耦合度。
Feign本身并不支持Spring MVC的注解,它有一套自己的注解,为了更方便的使用,Spring Cloud孵化了OpenFeign。
二、Feign能解决什么问题
Feign旨在使编写Java HTTP客户端变得更加容易,Feign简化了RestTemplate代码,实现了Bibbon负载均衡,使代码变得更加简洁,也减少了客户端调用的代码,使用Feign实现负载均衡是官方首选,只需要你创建一个接口,然后在上面添加注解即可。
Feign是声明式服务调用组件,其核心是:像调用本地方法一样调用远程方法,无感知远程HTTP请求。
它解决了让开发者调用远程接口就跟调用本地方法一样的体验,开发者完全感知不到这是远程方法,更感知不到这是个HTTP请求,无需关注与远程交互的细节。它像Dubbo一样,Consumer直接调用Provider接口方法,而不需要通过常规的HTTP Client构造请求再解析返回数据。
三、Spring Cloud 调用方Feign
(1)调用方,简化微服务API调用
(2)Feign是一种声明式、模板化的HTTP客户端
(3)简化Http客户端开发
(4)只需要创建一个接口+@注解
(5)Feign 注解和JAX-RS注解
(6)Feign支持可插拔的编码器和解码器
(7)Feign默认集成了Ribbon,并和Eureka结合
(8)Eclipse或者 IDEA实战
四、搭建Feign实例
1.首先搭建Eureka Server (之前搭建的就可以用)
2.创建服务提供者eureka-provider,在服务提供者中创建controller包,并在该包下创建HelloController类。该类定义一个sayHello()方法,用于处理路径为/hello的请求。
3.创建Feign命名为eureka-feign-client,添加Eureka,Feign,Web依赖。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
4.配置全局配置文件application.yml
server:
port: 7006
spring:
application:
name: eureka-provider
eureka:
client:
service-url:
defaultZone: http://localhost:7000/eureka/
instance:
hostname: localhost
5.在启动类EurekaFeignClientApplication中添加注解。
6.在eureka-feign-client中创建service包,并在该包下创建接口FeignService。
7.在eureka-feign-client中创建controller包,并在该包下创建FeignController类。
8.测试运行