Spring Cloud超详细i讲解Feign自定义配置与使用

目录
  • 日志配置
  • Basic 认证配置
  • 超时时间配置
  • 客户端组件配置
  • GZIP压缩配置
  • 继承特性
  • 多参数请求构造

日志配置

有时候我们遇到 Bug,比如接口调用失败、参数没收到等

问题,或者想看看调用性能,就需要配置 Feign 的日志了,

以此让 Feign 把请求信息输出来。

首先定义一个配置类,代码如下所示。

package com.by.config;
 import feign.Logger;
  import org.springframework.context.annotation.Bean;
   import org.springframework.context.annotation.Configu ration;
   @Configuration public class FeignConfig {
   @Bean
   Logger.Level feignLogLevel(){
    return Logger.Level.FULL;
    }
     }

通过源码可以看到日志等级有 4 种,分别是:

  • NONE:不输出日志。
  • BASIC:只输出请求方法的 URL 和响应的状态码以及接 口执行的时间。
  • HEADERS:将 BASIC 信息和请求头信息输出。
  • FULL:输出完整的请求信息。

在 Feign Client 中的 @FeignClient 注解中指定使用的配置类,代码如下所示。

@FeignClient(value = "ws-user- server",configuration = {FeignConfig.class})
 public interface UserRemoteClient {
  @GetMapping("/user/{id}")
  Map getuser(@PathVariable(name = "id") String id); }

在配置文件中执行 Client 的日志级别才能正常输出日志,

格式是“logging.level.client 类地址=级别”。

logging: 
  level: 
    com.by.remote.UserRemoteClient: debug

Basic 认证配置

通常我们调用的接口都是有权限控制的,很多时候可能认证

的值是通过参数去传递的,还有就是通过请求头去传递认证

信息,比如 Basic 认证方式。在 Feign 中我们可以直接配置

Basic 认证,代码如下所示。

@Configuration
public class FeignConfig {
public BasicAuthRequestInterceptor basicAuthRequestInterceptor(){
return new BasicAuthRequestInterceptor("admin","1357");
} }

或者你可以自定义属于自己的认证方式,其实就是自定义一

个请求拦截器。在请求之前做认证操作,然后往请求头中设

置认证之后的信息。通过实现 RequestInterceptor 接口来

自定义认证方式,代码如下所示。

import feign.RequestInterceptor;
import feign.RequestTemplate;
public class FeignAuthInteceptor implements RequestInterceptor {
@Override public void apply(RequestTemplate requestTemplate) {
requestTemplate.header("token","");
 }
 }

然后将配置改成我们自定义的就可以了,这样当 Feign 去请

求接口的时候,每次请求之前都会进入

FeignAuthInteceptor的 apply 方法中,在里面就可以做属

于你的逻辑了,代码如下所示。

@Configuration public class FeignConfig {
@Bean public RequestInterceptor basicAuthRequestInterceptor(){
return new FeignAuthInteceptor(); } }

超时时间配置

通过 Options 可以配置连接超时时间和读取超时时间(代

码如下所示),Options 的第一个参数是连接超时时间

(ms),默认值是 10×1000;第二个是取超时时间

(ms),默认值是 60×1000。

@Configuration public class FeignConfig {
@Bean public Request.Options options() {
return new Request.Options(5, TimeUnit.SECONDS,6,TimeUnit.SECONDS,true);
 }
  }

客户端组件配置

Feign 中默认使用apache httpclient 发送 HTTP 请求,我

们可以集成别的组件来替换掉,比如,OkHttp。

配置 OkHttp 只需要加入 OkHttp 的依赖,代码如下所示。

<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-okhttp</artifactId>
</dependency>

然后修改配置,将 Feign 的 HttpClient 禁用,启用

OkHttp,配置如下:

feign: 
  httpclient:
   enabled: false #禁用
    okhttp:
     enabled: true # 启用

关于配置可参考源码

org.springframework.cloud.openfeign.FeignAutoCon

figuration

GZIP压缩配置

开启压缩可以有效节约网络资源,提升接口性能,我们可以

配置 GZIP 来压缩数据:

feign:
 compression:
  request:
   enabled: true
  response:
   enabled: true

还可以配置压缩的类型、最小压缩值的标准:

feign:
 compression:
  request:
   enabled: true
    mime-types: text/xml,application/xml,application/json min-request-size: 2048

只有当 Feign 的 Http Client 不是 okhttp3 的时候,压缩才

会生效,配置源码在 org.springframework.cloud.openfeign.encoding.FeignAcceptGzipE

ncodingAutoConfiguration,代码如下所示。

@Configuration( proxyBeanMethods = false )
@EnableConfigurationProperties({FeignClientEnc odingProperties.class})
@ConditionalOnClass({Feign.class})
 @ConditionalOnBean({Client.class})
 @ConditionalOnProperty( value = {"feign.compression.response.enabled"}, matchIfMissing = false )
 @ConditionalOnMissingBean( type = {"okhttp3.OkHttpClient"} )
 @AutoConfigureAfter({FeignAutoConfiguration.cl ass})
 public class FeignAcceptGzipEncodingAutoConfiguration {
 public FeignAcceptGzipEncodingAutoConfiguration() { }
 @Beanpublic
 FeignAcceptGzipEncodingInterceptor feignAcceptGzipEncodingInterceptor(FeignClient EncodingProperties properties) {
 return new FeignAcceptGzipEncodingInterceptor(properties) ;
 }
 }

核心代码就是 @ConditionalOnMissingBean

(type=“okhttp3.OkHttpClient”),表示 Spring

BeanFactory 中不包含指定的 bean 时条件匹配,也就是没

有启用 okhttp3 时才会进行压缩配置。

继承特性

Feign 的继承特性可以让服务的接口定义单独抽出来,作为

公共的依赖,以方便使用。

创建一个module,用于存放 API 接口的定义,增加 Feign

的依赖,定义接口,指定服务名称,代码如下所示

package com.by.client;
 import org.springframework.cloud.openfeign.FeignClien t;
 import org.springframework.web.bind.annotation.GetMap ping;
 import java.util.Map;
  @FeignClient(value = "ws-user-server") public interface UserRemoteClient {
  @GetMapping("/user/{id}")
   public Map getuser(@PathVariable(name = "id") String id);
    }

打包安装到仓库

修改用户中心实现,先引入依赖

<dependency>
<groupId>com.by</groupId>
<artifactId>ws-api</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>

实现 UserRemoteClient 接口,代码如下所示。

@RestController
public class UserController implements UserRemoteClient {
@Override public Map getuser(@PathVariable(name="id") String id) {
Map map=new HashMap();
 map.put("id",id);
  map.put("name","管理员");
   return map;
   }
   }

修改订单服务,同样引入api,调用代码

@RestController
public class OrderController {
@Autowired
UserRemoteClient userRemoteClient;
 @GetMapping("/order/query") public Map query(){
 Map map=userRemoteClient.getuser("40");
 Map rs=new HashMap();
 rs.put("orderNum","dd002");
  rs.put("user",map); return rs; }
  }

多参数请求构造

多参数请求构造分为 GET 请求和 POST 请求两种方式,首

先来看 GET 请求的多参数请求构造方式,代码如下所示。

@GetMapping("/user/info")
String getUserInfo(@RequestParam("name")String name,@RequestParam("age")int age);

另一种是通过 Map 来传递多个参数,参数数量可以动态改

变,笔者在这里还是推荐大家用固定的参数方式,不要用

Map 来传递参数,Map 传递参数最大的问题是可以随意传

参。代码如下所示。

@GetMapping("/user/detail")
String getUserDetail(@RequestParam Map<String, Object> param);

POST 请求多参数就定义一个参数类,通过

@RequestBody 注解的方式来实现,代码如下所示。

@PostMapping("/user/add")
String addUser(@RequestBody User user);

注意: @RequestBody @PathVariable 在实现类上也要

加上注解

@RestController
public class UserController implements UserRemoteClient {
@Override public Map getuser(@PathVariable(name="id") String id) {
Map map=new HashMap();
 map.put("id",id);
 map.put("name","管理员");
 return map; }
 }

到此这篇关于Spring Cloud超详细i讲解Feign自定义配置与使用的文章就介绍到这了,更多相关Spring Cloud Feign内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • SpringCloud Feign请求头删除修改的操作代码

    Feign请求头修改删除操作 @Configuration public class ClientConfiguration { @Bean public RequestInterceptor headerInterceptor() { return new RequestInterceptor() { @Override public void apply(RequestTemplate template) { HttpServletRequest httpServletRequest = (

  • SpringCloud使用Feign实现动态路由操作

    目录 一.理解及原理 1.1理解 1.2原理 二.Feign搭建实现步骤 三.配置文件(pom.xml) 三.程序代码 四.结果演示 一.理解及原理 1.1理解 Feign基于接口 + 注解的方式,一个http请求调用的轻量级框架 Feign是Netflix开发的声明式.模板化的HTTP客户端, Feign可以帮助我们更快捷.优雅地调用HTTP API. Feign是一种声明式.模板化的HTTP客户端(仅在Application Client中使用).声明式调用是指,就像调用本地方法一样调用远程

  • SpringCloud基于Feign的可编程式接口调用实现

    目录 前言 一.基本使用 1.引依赖 2.加注解 3.声明接口 4.调用 二.进阶 1.日志配置 2.性能优化 前言 Feign 可以替代 RestTemplate 完成可编程式接口调用,并且内部集成 Ribbon 实现了负载均衡 一.基本使用 1.引依赖 pom文件增加 openfeign 依赖 <!-- feign --> <dependency> <groupId>org.springframework.cloud</groupId> <arti

  • SpringCloud Feign多参数传递及需要注意的问题

    目录 Feign多参数传递及注意的问题 在服务提供者cloud-shop-userservice中新增几个方法 修改feign的UserService,新增对应的方法 在feign的controller中调用方法 重启修改过的服务,查看服务注册是否正常 使用工具调用这几个方法进行测试 Feign如何接收多个参数 1.API 2.Feign 3.controller Feign多参数传递及注意的问题 这边沿用前面的Eureka,Feign,Service 在服务提供者cloud-shop-user

  • springcloud使用feign调用服务时参数内容过大问题

    目录 feign调用服务时参数内容过大 场景 解决方法 feign消费时,如果传入参数过长 导致feign.FeignException: status 400 reading错误 解决办法 feign调用服务时参数内容过大 场景 前端参数传入到gateway后,gateway使用feign调用服务时,传入的参数内容过大(参数常见于富文本.或者其他附属信息过多)会导致传输不过去,虽然配置可以调节内容大小,但是最大的也有上限,所以特殊处理一道. 例如该类参数: 解决方法 可新增两个redis公共方

  • Springcloud feign传日期类型参数报错的解决方案

    目录 feign传日期类型参数报错 Date类型参数报错 LocalDate类型报错 feign传参问题及传输Date类型参数时差的坑 下面说说两种解决方案 feign传参时候使用@DateTimeFormat注解的坑 feign传日期类型参数报错 Date类型参数报错 在Spring cloud feign接口中传递Date类型参数时报错,报错信息. 场景: 客户端传递一个new Date()的参数,服务端接受的参数和客户端有时间差. 客户端打印格式化的new Date(): 2018-05-

  • springcloud feign传输List的坑及解决

    目录 feign传输List的坑 错误方法1 错误方法2 错误方法3 feign调用传List接不到值 feign传输List的坑 无法直接传输List 错误方法1 @RequestMapping(value = "/stat/merchant/get_merchant_compare_info", method = RequestMethod.POST) @ResponseBody MerchantCompareTotalInfo getMerchantCompareInfo(  

  • 解决SpringCloud Feign异步调用传参问题

    背景 各个子系统之间通过feign调用,每个服务提供方需要验证每个请求header里的token. public void invokeFeign() throws Exception { feignService1.method(); feignService2.method(); feignService3.method(); .... } 定义拦截每次发送feign调用拦截器RequestInterceptor的子类,每次发送feign请求前将token带入请求头 @Configurati

  • SpringCloud Feign 传输Date类型参数存在误差的问题

    目录 Feign传输Date类型参数存在误差 时间转换代码如下 Feign传输date类型参数,时间差14个小时 JavaDate类型的时差问题 解决方法 Feign客户端的问题 解决方法 Feign传输Date类型参数存在误差 最近在项目开发过程中,前端传递过来的时间(Date类型)在A模块是正确的,然后A模块调用B模块将时间(Date类型)作为参数传过去,然后B模块接收到的时间有误差,天数会多一天,小时少10小时,这应该是SpringCloud Feign组件造成的问题 我这里的解决办法是在

  • Spring Cloud超详细i讲解Feign自定义配置与使用

    目录 日志配置 Basic 认证配置 超时时间配置 客户端组件配置 GZIP压缩配置 继承特性 多参数请求构造 日志配置 有时候我们遇到 Bug,比如接口调用失败.参数没收到等 问题,或者想看看调用性能,就需要配置 Feign 的日志了, 以此让 Feign 把请求信息输出来. 首先定义一个配置类,代码如下所示. package com.by.config; import feign.Logger; import org.springframework.context.annotation.Be

  • Spring Boot超详细讲解请求处理流程机制

    目录 1. 背景 2. Spring Boot 的请求处理流程设计 3. Servlet服务模式请求流程分析 3.1 ServletWebServerApplicationContext分析 3.2 Servlet服务模式之请求流程具体分析 4. Reactive服务模式请求流程分析 4.1 ReactiveWebServerApplicationContext分析 4.2 webflux服务模式之请求流程具体分析 5. 总结 1. 背景 之前我们对Spring Boot做了研究讲解,我们知道怎

  • Spring Cloud Feign 自定义配置(重试、拦截与错误码处理) 代码实践

    基于 spring-boot-starter-parent 2.1.9.RELEASE, spring-cloud-openfeign 2.1.3.RELEASE 引子 Feign 是一个声明式.模板化的HTTP客户端,简化了系统发起Http请求.创建它时,只需要创建一个接口,然后加上FeignClient注解,使用它时,就像调用本地方法一样,作为开发者的我们完全感知不到这是在调用远程的方法,也感知不到背后发起了HTTP请求: /** * @author axin * @suammry xx 客

  • Spring Data JPA实现排序与分页查询超详细流程讲解

    目录 前言 1.创建持久化实体类 2.创建数据访问层 3.创建业务层 4.创建控制器类 5.创建View视图页面 6.运行主类 效果如下 前言 在实际开发场景中,排序与分页查询是必须的,幸运的是Spring Data JPA充分考虑了排序与分页查询的场景,为我们提供Sort类 Page接口 Pageable接口 下面通过一个实战来阐明 1.创建持久化实体类 创建名为com.ch.ch6_4.entity的包 并在该包中创建名为Article和Author的持久化实体类 代码如下 Article

  • Java 泛型超详细入门讲解

    目录 1.什么是泛型? 2.泛型是怎么编译的 泛型的编译机制:擦除机制 1.什么是泛型? 泛型其实就是将类型作为参数传递,泛型允许程序员在编写代码时使用一些以后才指定的类型 ,在实例化该类时将想要的类型作为参数传递,来指明这些类型. 为什么要引入泛型? 例如:自己实现一个顺序表 public class MyArrayList { public int[] elem; public int usedSize; public MyArrayList() { this.elem = new int[

  • Java 泛型超详细入门讲解

    目录 1.什么是泛型? 2.泛型是怎么编译的 泛型的编译机制:擦除机制 1.什么是泛型? 泛型其实就是将类型作为参数传递,泛型允许程序员在编写代码时使用一些以后才指定的类型 ,在实例化该类时将想要的类型作为参数传递,来指明这些类型. 为什么要引入泛型? 例如:自己实现一个顺序表 public class MyArrayList { public int[] elem; public int usedSize; public MyArrayList() { this.elem = new int[

  • Spring Boot超详细分析启动流程

    目录 一.Spring Boot 工程结构 二.Spring Boot 启动流程 三.Spring Boot 启动流程源码剖析 1.创建一个Spring Boot 工程 2.SpringBootApplication启动入口 3.Spring Boot 初始化分析 4.Spring Boot 启动深入分析 四.总结 一.Spring Boot 工程结构 下载Spring Boot工程源码, 下载地址 模块代码结构: 比较重要的是Spring-boot.Spring-boot-autoconfig

  • SpringBoot超详细深入讲解底层原理

    目录 手写springboot Springboot项目 自动配置 小结 手写springboot 在日常开发中只需要引入下面的依赖就可以开发Servlet进行访问了. <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> 那这是怎么做到的呢?今天就来

  • Java 栈与队列超详细分析讲解

    目录 一.栈(Stack) 1.什么是栈? 2.栈的常见方法 3.自己实现一个栈(底层用一个数组实现) 二.队列(Queue) 1.什么是队列? 2.队列的常见方法 3.队列的实现(单链表实现) 4.循环队列 一.栈(Stack) 1.什么是栈? 栈其实就是一种数据结构 - 先进后出(先入栈的数据后出来,最先入栈的数据会被压入栈底) 什么是java虚拟机栈? java虚拟机栈只是JVM当中的一块内存,该内存一般用来存放 例如:局部变量当调用函数时,我们会为函数开辟一块内存,叫做 栈帧,在 jav

  • C语言 超详细总结讲解二叉树的概念与使用

    目录 1.二叉树的概念及结构 2.二叉树链式结构的实现 1.二叉树的概念及结构 ①概念:一棵二叉树是结点的一个有限集合,该集合或者为空,或者是由一个根节点加上两棵别称为左子树和右子树的二叉树组成. ②二叉树的特点: 每个结点最多有两棵子树,即二叉树不存在度大于2的结点.(度最多为2) 二叉树的子树有左右之分,其子树的次序不能颠倒. ③现实中的二叉树: 当一名普通的人看到这样一颗树,可能会想:好标准的一棵树 当一个程序猿看到这样一棵树,可能会想:好像数据结构中的二叉树,并且还是颗满二叉树 ④数据结

随机推荐