8-2、Feign支持的其他组件介绍及配置

一、Feign对负载均衡Ribbon的⽀持

Feign 本身已经集成了Ribbon依赖和⾃动配置,因此我们不需要额外引⼊依赖,可以通过 ribbon.xx 来进行全局配置,也可以通过服务名.ribbon.xx 来对指定服务进行细节配置配置(参考之前,此处略)

Feign默认的请求处理超时时长为1s,有时候我们的业务确实执行的需要⼀定时间,那么这个时候,我们就需要调整请求处理超时时长,Feign自己有超时设置,如果配置Ribbon的超时,则会以Ribbon的为准

#针对的被调用方微服务名称,不加就是全局生效
lagou-service-resume:
  ribbon:
    #请求连接超时时间
    ConnectTimeout: 2000
    #请求处理超时时间
    ##########################################Feign超时时长设置
    ReadTimeout: 3000
    #对所有操作都进行重试
    OkToRetryOnAllOperations: true
    ####根据如上配置,当访问到故障请求的时候,它会再尝试访问一次当前实例(次数由MaxAutoRetries配置),
    ####如果不行,就换一个实例进行访问,如果还不行,再换一次实例访问(更换次数由MaxAutoRetriesNextServer配置),
    ####如果依然不行,返回失败信息。
    MaxAutoRetries: 0 #对当前选中实例重试次数,不包括第一次调用
    MaxAutoRetriesNextServer: 0 #切换实例的重试次数
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule #负载策略调整

二、Feign对熔断器hystrix的⽀持

(一)开启配置

# 开启Feign的熔断功能
feign:
  hystrix:
    enabled: true

(二)超时时长配置

  1. Feign的超时时⻓设置其就是上⾯Ribbon的超时时⻓设置
  2. Hystrix超时设置(就按照之前Hystrix设置的⽅式就OK了)
  3. 同时设置的话,以设置的时间短的为准

注意:

  • 1)开启Hystrix之后,Feign中的⽅法都会被管理,⼀旦出现问题就进⼊对应的回退逻辑处理
  • 2)针对超时这⼀点,当前有两个超时时间设置(Feign/hystrix),熔断的时候是根据这两个时间的最⼩值来进⾏的,即处理时⻓超过最短的那个超时时间了就熔断进⼊回退降级逻辑
hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            ##########################################Hystrix的超时时长设置
            timeoutInMilliseconds: 15000

在这里插入图片描述

(三)自定义FallBack处理类(需要实现FeignClient接⼝)

服务降级,返回默认值

1、定义一个类,实现FeignClient接口

降级回退逻辑需要定义一个类,实现FeignClient接口,实现接口中的方法

package com.lagou.edu.config;

import org.springframework.stereotype.Component;

/**
 *
 * 降级回退逻辑需要定义一个类,实现FeignClient接口,实现接口中的方法
 */
@Component
public class ResumeFallback implements ResumeFeignClient{
    @Override
    public Integer findDefaultResumeByUserId(Integer userId) {
        return -666;
    }
}


2、FeignClient类注解需要调整

/*
@FeignClient(name = "lagou-service-resume")
@RequestMapping("/resume") // 与服务提供者controller的RequestMapping保持一致
*/
/**
 * 使⽤fallback的时候,类上的@RequestMapping的url前缀限定,改成配置在@FeignClient的path属性中
 */
@FeignClient(name = "lagou-service-resume",fallback = ResumeFallback.class,path = "/resume")

3、测试

在这里插入图片描述

三、Feign的⽇志级别配置

Feign是http请求客户端,类似于咱们的浏览器,它在请求和接收响应的时候,可以打印出⽐较详细的⼀些⽇志信息(响应头,状态码等等)

如果我们想看到Feign请求时的⽇志,我们可以进⾏配置,默认情况下Feign的⽇志没有开启。

(一)开启Feign⽇志功能及级别

package com.lagou.edu.config;

import feign.Logger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * 
 * TODO Feign的⽇志级别(Feign请求过程信息)
 *  1、NONE:默认的,不显示任何⽇志----性能最好
 *  2、BASIC:仅记录请求⽅法、URL、响应状态码以及执⾏时间----⽣产问题追踪
 *  3、HEADERS:在BASIC级别的基础上,记录请求和响应的header
 *  4、FULL:记录请求和响应的header、body和元数据----适⽤于开发及测试环境定位问
 * 题
 */
@Configuration
public class FeignLog {

    @Bean
    Logger.Level feignLevel() {
        return Logger.Level.FULL;
    }
}


(二)配置log⽇志级别为debug

logging:
  level:
    # Feign日志只会对日志级别为debug的做出响应
    com.lagou.edu.controller.service.ResumeServiceFeignClient: debug

四、Feign对请求压缩和响应压缩的⽀持

Feign ⽀持对请求和响应进⾏GZIP压缩,以减少通信过程中的性能损耗。

通过下⾯的参数 即可开启请求与响应的压缩功能:

feign:
	compression:
		request:
			enabled: true # 开启请求压缩
			mime-types: text/html,application/xml,application/json# 设置压缩的数据类型,此处也是默认值
			min-request-size: 2048 # 设置触发压缩的⼤⼩下限,此处也是默认值
		response:
			enabled: true # 开启响应压缩
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值