Feign入门

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: Feign入门

1、简介

Feign是一个REST客户端库,它通过接口驱动的方式来定义REST客户端。Spring Cloud Netflix体系中的Eureka服务注册中心客户端支持Ribbon客户端负载均衡器,而Feign本质上是Ribbon的包装,其内部是通过Ribbon来进行服务查找和负载均衡。 在Spring Cloud Netflix体系中,我们通常会通过以下两种方式进行服务通信:


支持负载均衡的RestTemplate


Feign生成的客户端接口


两种方式都是通过Ribbon进行服务查找,然后更加负载均衡策略选择服务进行服务通信,具体使用那种方式看个人爱好(小捌觉得Feign客户端接口这种方式,在代码上稍显复杂,但是更好管理)。


关于Feign的一点小知识: 大家经常听到有人说OpenFeign,有人说Feign,给人一种好像是两个东西的错觉。其实是因为Feign本身也是Netflix的开源项目,后面独立出来单独做了开源项目,改名为OpenFeign。这种情况其实很常见,比如鸿蒙-HarmonyOS就有Open HarmonyOS。


2、正文

正式开始Feign的学习之前,大家需要对微服务有一定的认识,关于这些知识点可以查看本专栏的往期文章,入门微服务、Eureka相关知识,并且搭建一个Eureka服务和客户端之后在来学习Feign。


2.1 服务搭建

搭建一个Eureka Server用于服务注册发现,此外准备两个相同的服务提供者SERVER和一个服务消费者CONSUMER,整体的服务如下所示:

image.pngimage.pngimage.pngimage.pngimage.png2.4 总结

这篇文章入门了Feign,也顺带讲了下RestTemplate的简单使用。需要注意的是Fegin它并不负责解析服务名、负载均衡,这些都是其集成的Ribbon实现的。Feign可以替代RestTemplate,相比之下代码的可读性确实增强了,但是整体性能是有些许下降的。


相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
SpringCloud极简入门-Feign开启Hystrix
1.支付服务集成Hystrix 官方文档:https://cloud.spring.io/spring-cloud-static/Greenwich.SR5/single/spring-cloud.html#spring-cloud-feign-hystrix 支付服务 springcloud-pay-server-1040 之前集成了Feign,修改该工程集成Hystrix。我们除了要给Feign开启Hystrix以外还需要为Feign接口编写托底类。
191 0
|
5月前
Feign使用原理
Feign使用原理
126 0
|
6月前
|
XML JSON Java
经验大分享:SpringCloud之Feign
经验大分享:SpringCloud之Feign
77 0
|
7月前
|
负载均衡 Java 应用服务中间件
Ribbon、Feign和OpenFeign的区别来了
Ribbon、Feign和OpenFeign的区别来了
310 2
|
负载均衡 Dubbo Java
简单理解Feign的原理与使用
简单理解Feign的原理与使用
235 0
|
负载均衡 Java
10SpringCloud - Feign简介
10SpringCloud - Feign简介
43 0
|
负载均衡 Java API
Spring Cloud 之 Feign 简介及简单使用
Spring Cloud 之 Feign 简介及简单使用
173 0
|
设计模式 缓存 Dubbo
|
JSON 负载均衡 算法
9、Eureka、Feign、Ribbon的工作原理及项目实战
在前后端分离架构中,服务层被拆分成了很多的微服务,Spring Cloud中提供服务注册中心来管理微服务信息
189 0
9、Eureka、Feign、Ribbon的工作原理及项目实战
|
负载均衡 算法 Java
SpringCloud-04 Feign学习笔记
SpringCloud-04 Feign学习笔记
SpringCloud-04 Feign学习笔记