Spring cloud 服务调用 feign

Feign

简介

(Feign = RestTemplate+Ribbon+Hystrix )

Feign是Netflix开发的⼀个轻量级RESTfulHTTP服务客户端(⽤它来发起请求,远程调⽤的)

类似dubbo,服务消费者拿到提供者的接口,像调用本地方法一样调用接口中的方法,实际发出的是远程的请求。

本质:封装了http调用流程,更符合面向接口化的编程习惯

/**
 * 1.name属性用于指定要调用微服务的名称,对应在注册中心的名称。
 * 2.openFeign支持springmvc注解,接口中的方法相当于远程服务controller的handler方法。
 * 3.使用接口中的方法完成远程调用(注入接口接口,实际注入的是实现类)
 * @author renpeiqian
 * @date 2021/7/15 14:51
 * @since
 */
@FeignClient(name = "lagou-service-resume")
public interface   ResumeServiceApi {

    /**
     * @Description 使用Feign调用简历服务接口
     * @Param [userId]  用户id
     * @return java.lang.Integer
     */
    @RequestMapping(value = "/resume/state/{userId}",method = RequestMethod.GET)
    Integer check(@PathVariable(value = "userId") Long userId);
}

复杂均衡

Feign集成了Ribbon依赖和自动配置,可以通过ribbon配置修改负载均衡策略。

熔断器

熔断器默认是关闭,需要在配置文件中开启

feign:
  #开启熔断器
  hystrix:
    enabled: true

注意点:

  • 开启熔断器后,feign中所有方法都会被加入容错机制,一旦出现错误,就会执行回退逻辑
  • feign、hystrix都有超时时间设置,同时设置时以两者之间的值为准。

Fegin集成hystrix

1.编写Fallbak类,实现FeignClient接口

/**
 * 简历微服务回调类 :用于简历微服务不可用或者响应时间过长,发生熔断机制后回调,给予用户后者消费者错误信息
 * @author renpeiqian
 * @date 2021/7/15 15:59
 * @since
 */
@Component //注入ioc容器
public class ResumeServiceFallBack implements ResumeServiceApi {
    @Override
    public Integer check(Long userId) {
        return -6;
    }
}

2.在接口中引入fallback类

@FeignClient(name = "lagou-service-resume" ,fallback = ResumeServiceFallBack.class)
@RequestMapping("/resume")
//在引入fallbak类 ,需将requestMapping写入feignclient的path中
//@FeignClient(name = "lagou-service-resume" ,fallback = ResumeServiceFallBack.class,path="/resum")
@RequestMapping("/resume")
public interface  ResumeServiceApi {

    /**
     * @Description 使用Feign调用简历服务接口
     * @Param [userId]  用户id
     * @return java.lang.Integer
     */
    @RequestMapping(value = "/resume/state/{userId}",method = RequestMethod.GET)
    Integer check(@PathVariable(value = "userId") Long userId);
}

请求和响应压缩

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

feign:
	compression:
		request:
			enabled: true # 开启请求压缩
			mime-types: text/html,application/xml,application/json # 设置压缩的数据类型,此处也是默认值
			min-request-size: 2048 # 设置触发压缩的⼤⼩下限,此处也是默认值
		response:
			enabled: true # 开启响应压缩
日志配置

Feign是http请求客户端,在请求和响应的时候,可以打印出比较详细的日志。(请求头、请求体等)

默认日志是没有开启的。

1.开启Feign⽇志功能及级别

/**
 * @author renpeiqian
 * @date 2021/7/15 16:21
 * @since
 */
@Configuration
public class FeignConfig {

    /**
     * @Description
     * Feign日志级别(请求过程信息)
     * NONE:默认的,不显示任何⽇志----性能最好
     * BASIC:仅记录请求⽅法、 URL、响应状态码以及执⾏时间----⽣产问题追踪
     * HEADERS:在BASIC级别的基础上,记录请求和响应的header
     * FULL:记录请求和响应的header、 body和元数据----适⽤于开发及测试环境定位问题
     * @Param []
     * @return feign.Logger.Level
     */
    @Bean
    Logger.Level feignLevel() {
        return Logger.Level.FULL;
    }

}

2.配置系统log⽇志级别为debug

logging:
  level:
    # Feign⽇志只会对⽇志级别为debug的做出响应
    com.lagou.edu.api.ResumeServiceApi:
      debug
源码分析

采用jdk动态代理,对方法增强。底层请求发起是HttpURLConnection

//todo

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值