探索Feign

news2024/9/25 9:34:07

目录

1. 简介

2. 原理

2.1. 动态代理 动态代理 动态代理

2.2. 懒加载负载均衡器的问题与解决

2.3. 主要类

3. 使用举例

4. 参数配置


1. 简介

Feign,一种声明式的web service client,可以很容易的创建http apis client。创建一个interface并添加注解,即可使用Feign。

简化http api调用的同时,支持多种http-client、协议、编解码方式。

Spring Cloud为Feign提供了"集成Ribbon和Eureka的负载均衡http client"。

2. 原理

2.1. 动态代理 动态代理 动态代理

2.2. 懒加载负载均衡器的问题与解决

feignclient第一次调用时,才会生成负载均衡器,从eureka server获取serverlist。因此会导致第一次调用较慢。可以通过配置解决该问题。

ribbon.eager-load.enabled:开启Ribbon的饥饿加载模式
ribbon.eager-load.clients:必须指定需要饥饿加载的客户端名称、服务名

2.3. 主要类

FeignClientsRegistrar#registerFeignClients扫描使用@FeignClient注解的class,注册到spring context中,即加入beanFactory#beanDefinitionMap。
FeignClientFactoryBean#getObject生成feign客户端代理,例如Feign.builder().target(……)
DynamicServerListLoadBalancer构造方法中就会去eureka server获取serverlist
feign.Feign作为工厂,生成接口代理
FeignInvocationHandler#invokefeign客户端代理调用控制器
feign.SynchronousMethodHandler#invokefeign客户端方法处理器,构建requestTemplate,http client发起请求,重试,解码返回值等。
LoadBalancerFeignClient#execute
AbstractLoadBalancerAwareClient#executeWithLoadBalancer
RetryableFeignLoadBalancer#execute
LoadBalancerCommand#selectServer
负载均衡,分发请求
选择应用标识对应服务实例ip:port
执行http1.1请求

3. 使用举例

3.1. maven 依赖

org.springframework.cloud:spring-cloud-starter-openfeign:1.4.5.RELEASE

3.2. @EnableFeignClients

3.3. 定义一个interface

@FeignClient("服务提供方应用标识/服务ID")
不同环境应用标识不同,如assets-springcloud-dev、assets-springcloud-test、assets-springcloud-prod。

stores 表示一个client name,用于创建Ribbon负载均衡器;可使用qualifier属性规定client bean别名。

Ribbon client将尝试发现stores服务的物理地址,如果应用是Eureka client,将通过Eureka服务器发现服务地址。

3.4. 使用方式

服务提供方暴露api包
服务提供方实现api
服务调用方实现api且加@FeignClient

 也可以在暴露的api使用@FeignClient。

4. 参数配置

优先选择 在配置文件中添加配置项,支持通用配置和特定client配置。

特定client的配置

feign:
  client:
    config:
      feignName:
        connectTimeout: 5000
        readTimeout: 5000
        loggerLevel: full
        errorDecoder: com.example.SimpleErrorDecoder
        retryer: com.example.SimpleRetryer
        requestInterceptors:
          - com.example.FooRequestInterceptor
          - com.example.BarRequestInterceptor
        decode404: false

通用配置

feign:
  client:
    config:
      default:
        connectTimeout: 5000
        readTimeout: 5000
        loggerLevel: basic

参考

https://github.com/OpenFeign/feign


    

    

    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/127563.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Cubase11/12 Windows 音乐创作工具

前言 Cubase是一款专业级的高级音乐创作软件,凭借其无与伦比的灵活工具,您可以快速和直观地创造任何类型的音,充满了各种各样的虚拟仪器、效果和数千种声音。 下载 官网:Cubase Cubase12 12详细教程 Cubase11教程 管理员身份运行 右击…

python初级教程四 发送邮件

SMTP发送邮件 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。 python的smtplib提供了一种很方便的途径发送电子邮件。它对smtp协议进行了简单的封装。 …

实力认证!中睿天下荣获“创客北京2022”软件与信息技术产业项目十强

近日,第七届“创客中国”北京市中小企业创新创业大赛暨“创客北京2022”创新创业大赛北京区域赛在决赛阶段按照八个产业对参赛项目进行评选,产生了各产业的十强项目,《中睿天下实战对抗攻击溯源项目》从数百个项目中脱颖而出,荣获…

MXNet的Faster R-CNN(基于区域提议网络的实时目标检测)《2》

上一篇文章 是对这个模型做个测试,效果很不错,然后这节,我们来关注下论文中的一些知识点 原论文:Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks 本文不是按照原论文的顺序一路下来讲解&…

Python基础语法(三)

Python基础语法(三) 列表和元组 列表是什么, 元组是什么 编程中, 经常需要使用变量, 来保存/表示数据. 如果代码中需要表示的数据个数比较少, 我们直接创建多个变量即可 num1 10 num2 20 num3 30 ......但是有的时候, 代码中需要表示的数据特别多…

小程序:后台交互-个人中心

目录 获取用户昵称头像和昵称 wx.getUserProfile bindgetuserinfo oa-mini 登录过程 登录-小程序 wx.checkSession wx.login wx.request 后台 准备数据表 反向生成工具生成 准备封装前端传过来的数据 小程序服器配置 导入微信小程序SDK application.yml WxPro…

我眼中的Java内存模型

一.JVM内存结构 (1)方法区只是一种概念上的区域,并说明了其应该具有什么功能,但是没有规定这个区域到底应该处于何处,不同版本的方法区所处位置不同,并不是绝对意义上的物理区域。 (2&#xff0…

CSRF攻击方式及预防准则

跨站点请求伪造(CSRF) 是一种攻击类型,当恶意网站、电子邮件、博客、即时消息或程序导致用户的Web浏览器在用户通过身份验证后对受信任的站点执行不需要的操作时,就会发生这种攻击。CSRF攻击之所以有效,是因为浏览器请…

OpenHarmony#深入浅出学习eTs#(二)拖拽式UI

本项目Gitee仓地址:深入浅出eTs学习: 带大家深入浅出学习eTs (gitee.com) 一、创建支持Super Visual的工程 在这里选择直尺Super Visual的选项,调整当前路径,进入绘制界面 二、UI设计界面介绍 在左侧是路径(即文件管理器&#x…

3.我们一起来学习Linux 安装

Linux 安装 本章节我们将为大家介绍 Linux 的安装,安装步骤比较繁琐,现在其实云服务器挺普遍的,价格也便宜,如果自己不想搭建,也可以直接买一台学习用用。 本章节以 centos6.4 为例。 可以去官网下载最新版本&…

【C语言进阶】通讯录再优化?学会文件操作,没有数据库也能保存和管理本地数据

目录 🥝前言🥝: 一、🍓文件概述🍓: 1.为什么使用文件: 2.什么是文件: ①.程序文件: ②.数据文件: ③.文件名: 二、🍊文件顺序读写&…

JAVA集成阿里云OSS对象存储

JAVA集成阿里云OSS对象存储1 : 配置集成1.1、对象存储OSS2 : 代码配置2.1、说明2.2、配置文件2.3、加载配置文件代码2.4、封装统一的DTO2.5、OSS上传Controller2.6、OSS上传Service2.7、OSS上传ServiceImpl3 : 测试3.1、文件上传3.2、文件迁移4 : 总结4.1、参考资料4.2、注意事…

浅谈 C++ 字符串:std::string 与它的替身们

浅谈 C 字符串:std::string 与它的替身们 文章目录浅谈 C 字符串:std::string 与它的替身们零、前言一、前辈:C 风格的字符串1.1 什么是 C 风格的字符串1.2 C 风格的字符串有什么缺陷1.2.1 以 \0 作为结尾,没有直接指明长度1.2.2 …

Android技术分享——APT实现ButterKnife【实战学习】

APT APT (Annotation Processing Tool) 是一种处理注释的工具,它对源代码文件进行检测并找出其中的 Annotation,根据注解自动生成代码,如果想要自定义的注解处理器能够运行,必须要通过 APT 工具来处理。 …

Python实现FA萤火虫优化算法优化支持向量机分类模型(SVC算法)项目实战

说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 萤火虫算法(Fire-fly algorithm,FA)由剑桥大学Yang于2009年提出 , 作…

maven第一篇:安装maven以及配置

本篇就是聊如何在电脑上安装maven,以及简单的配置基础环境。 首先需要了解什么适合maven,对于这个理论知识,还是老规矩直接复制一下; Maven 是一款基于 Java 平台的项目管理和整合工具,它将项目的开发和管理过程抽象…

提速300%,PaddleSpeech语音识别高性能部署方案重磅来袭!

在人机交互的过程中,语音是重要的信息载体,而语音交互技术离不开语音识别与语音合成技术。飞桨语音模型库PaddleSpeech为开发者们使用这些技术提供了便捷的环境。本次PaddleSpeech迎来重大更新——1.3版本正式发布。让我们一起看看,这次Paddl…

这样实操一下 JVM 调优,面试超加分

1.写在前面 前段时间一位读者面了阿里,在二面中被问到 GC 日志分析,感觉回答的不是很好,过来找我复盘,大致听了他的回答,虽然回答出了部分,但是没抓到重点。 GC 日志分析算是 JVM 调优中比较难的部分&…

【XR】如何提高追踪保真度,确保内向外追踪系统性能

Constellation是Oculus研发的追踪系统。日前,负责AR/VR设备输入追踪的Facebook工程经理安德鲁梅利姆撰文介绍了他们是如何用基于Constellation追踪的控制器来提高交互保真度。具体整理如下: 我们的计算机视觉工程师团队一直在努力为Oculus Quest和Rift …

【再学Tensorflow2】TensorFlow2的模型训练组件(1)

TensorFlow2的模型训练组件(1)数据管道构建数据通道应用数据转换提升管道性能特征列特征列用法简介特征列使用示例激活函数常用激活函数激活函数使用示例Tensorflow模型中的层内置的层自定义模型中的层参考资料Tensorflow中与模型训练相关的组件主要包括…