SpringCloud

SpringCloud ,第1张

目录
  • 一、Feign 介绍
  • 二、Feign 作用
  • 三、使用 Feign 实现消费者
  • 四、Feign 负载均衡


一、Feign 介绍

Feign 是 Netflix 公司开发的一个声明式的 REST 调用客户端 (调用远程的 Restful 风格的 Http 接口的一个组件)。

调用组件其实很多,比如:

1、HttpClient (Apache)
2、HttpURLConnection (JDK)
3、RestTemplate (Spring)
4、OKHttp (Android)
5、Feign (Netflix) --> 实现非常优雅

Spring Cloud Feign 对 Ribbon 负载均衡进行了简化,在其基础上进行了进一步的封装,在配置上大大简化了开发工作,它是一种声明式的调用方式,它的使用方法是定义一个接口,然后在接口上添加注解,使其支持了 Spring MVC 标准注解和 HttpMessageConverters,Feign 可以与 Eureka 和 Ribbon 组合使用以支持负载均衡。

二、Feign 作用

Feign 旨在简化微服务消费方 (调用者,客户端) 代码的开发,前面在使用 Ribbon + RestTemplate 进行服务调用时,利用 RestTemplate 对 Http 请求的封装处理,形成了一套模版化的调用方式。

但是在实际开发中,由于服务提供者提供的接口非常多,一个接口也可能会被多处调用,Feign 在 Ribbon+RestTemplate 的基础上做了进一步封装,在Feign 封装之后,我们只需创建一个接口并使用注解的方式来配置,即可完成对服务提供方的接口绑定,简化了使用 Ribbon + RestTemplate 的调用,自动封装服务调用客户端,减少代码开发量。

三、使用 Feign 实现消费者

使用 Feign 实现消费者,我们通过下面步骤进行

A、创建普通 Spring Boot 工程

把接口放在通用的接口层、常量类、model的项目中

B、添加依赖

要添加的依赖主要是 spring-cloud-starter-netflix-eureka-clientspring-cloud-starter-feign

我们可以在创建项目时,对相应的组件进行勾选

<denpendency>
    <groupId>org.springframework.cloudgroupId>
    <artifactId>spring-cloud-starter-openfeignartifactId>
denpendency>

C、声明服务

定义一个 GoodsRemoteClient 接口,通过 @FeignClient 注解来指定服务名称,进而绑定服务,然后再通过 SpringMVC 中提供的注解来绑定服务提供者提供的接口, 如下:

@FeignClient("springcloud-service-goods")
public interface GoodsService {
    @RequestMapping("/servcie/goods")
    public String goods() {
    }
}

这相当于绑定了一个名叫 springcloud-service-goods 的服务提供者提供的 /service/goods 接口

D、添加注解

在项目入口类上添加 @EnableFeignClients 注解表示开启 Spring Cloud Feign的支持功能

E、使用 Controller 中调用服务

接着来创建一个 Controller 来调用上面的服务,如下

public class GoodsController {
   @Autowired
   private GoodsService goodsService;
  
   @RequestMapping("/cloud/goodsFeign")
   public ResultObject goodsFeign() {
      return goodsService.goods()
   }
}

F、属性配置

在 application.properties 中指定服务注册中心、端口号等信息,如下:

server.port=8090
#打开所有的 web 访问端点
management.endpoints.web.exposure.include=*
#此实例注册到eureka服务端的 name
management.endpoints.name=springcloud-service-feign
#不注册自己,我是一个消费者,别人如果不调用我的话,我就不用注册
eureka.client.register-with-eureka=false
#每间隔2s,向服务端发送一次心跳,证明自己依然"存活"
eureka.instance.lease-renewal-interval-in-seconds=2
#告诉服务端,如果我10s之内没有给你发心跳,就代表我故障了,将我踢出掉
eureka.instance.lease-expiration-duration-in-seconds=10
#告诉服务端,服务实例以IP作为链接,而不是取机器名
eureka.instance.prefer-ip-address=true
#告诉服务端,服务实例的唯一ID
eureka.instance.instance-id=springcloud-service-feign
#eureka注册中心的连接地址
eureka.client.service-url.defaultZone=http://192.168.160.133:8761/eureka,http://192.168.160.133:8762/eureka,http://192.168.160.133:8763/eureka

G、测试

依次启动注册中心、服务提供者和 feign 实现服务消费者,然后访问如下地址:

http://localhost:8090/cloud/goodsFeign

四、Feign 负载均衡

我们知道,Spring Cloud 提供了 Ribbon 来实现负载均衡,使用 Ribbo 直接注入一个 RestTemplate 对象即可,RestTemplate 已经做好了负载均衡的配置。

在 Spring Cloud 下,使用 Feign 也是直接可以实现负载均衡的,定义一个有 @FeignClient 注解的接口,然后使用 @RequestMapping 注解到方法上映射远程的 REST 服务,此方法也是做好负载均衡配置的。

通过 Feign 只需要定义服务绑定接口且以声明式的方法,优雅而简单的实现了服务调用。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/756398.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-30
下一篇 2022-04-30

发表评论

登录后才能评论

评论列表(0条)

保存