服务调用Feign_Spring_cloud_4

本文介绍了Feign的基本概念,展示了如何在Spring Cloud中使用Feign进行服务调用,包括引入依赖、配置接口和启动激活。此外,还讨论了Feign与Ribbon的关系、负载均衡,并详细讲解了Feign的高级特性,如自定义配置、请求压缩、日志级别控制等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

当我们使用的RestTemplate实现REST API调用,代码大致如下:
@GetMapping("/buy/{id}")
   @RequestMapping(value = "/buyRibbon/{id}",method = RequestMethod.GET)
    public Product findByIdRibbon(@PathVariable Long id){
        Product product = restTemplate.getForObject("http://service-product/product/1",Product.class);
        return product;
    }

由代码可知,我们是使用拼接字符串的方式构造URL的,该URL只有一个参数。但是,在现实中,URL中往往含有多个参数。这时候我们如果还用这种方式构造URL,那么就会非常痛苦。那应该如何解决?让我们带着这样的疑问进行学习。

一.Feign简介

Feign是Netflix开发的声明式,模板化的HTTP客户端,其灵感来自Retrofit,JAXRS-2.0以及WebSocket.

  • Feign可帮助我们更加便捷,优雅的调用HTTP API。
  • 在SpringCloud中,使用Feign非常简单——创建一个接口,并在接口上添加一些注解,代码就完成了。
  • Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。
  • SpringCloud对Feign进行了增强,使Feign支持了SpringMVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。

二. 基于Feign的服务调用入门

1.引入依赖:

在服务消费者端引入以下依赖:
<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

2.配置调用的接口

package cn.itcast.order.feign;

import cn.itcast.order.entity.Product;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

/**
 * 声明需要调用的微服务名称
 * @FeignClient
 *      name:服务提供者的名称
 */
@FeignClient(name = "service-product")
public interface ProductFeignClient {

    /**
     * 配置需要调用的微服务接口
     * @param id
     * @return
     */
    @RequestMapping(value = "/product/{id}",method = RequestMethod.GET)
    public Product findById(@PathVariable("id")Long id);
}

3.在启动类上激活feign

@SpringBootApplication
@EntityScan("cn.itcast.order.entity")
//激活feign
@EnableFeignClients
public class OrderApplication {

4.通过自动的接口调用远程微服务

具体操作:在原有的controller层的类中,将第二步写的接口注入至controller中然后声明方法直接调用即可。
@RestController
@RequestMapping("/order")
public class OrderController {
	    //注入使用feign的接口
	    @Autowired
	    private ProductFeignClient productFeignClient;
	    /**
	     * 基于feign的形式调用远程服务
	     *
	     * @param id
	     * @return
	     */
   		 @RequestMapping(value = "/buyFeign/{id}",method = RequestMethod.GET)
   	 	public Product findByIdFeign(@PathVariable Long id){

        	//Product product = restTemplate.getForObject("http://service-product/product/1",Product.class);
        	Product product = productFeignClient.findById(id);
        	return product;
    	}
    }

三.Feign和Ribbon的联系

**Ribbon**是一个基于 HTTP 和 TCP 客户端 的负载均衡的工具。它可以在客户端 配置
	RibbonServerList(服务端列表),使用 HttpClient 或 RestTemplate 模拟http请求,步骤相当繁琐。
**Feign** 是在 Ribbon的基础上进行了一次改进,是一个使用起来更加方便的 HTTP 客户端。采用接口的方式, 只需要创建一个接口,
		然后在上面添加注解即可 ,将需要调用的其他服务的方法定义成抽象方法即可, 不需要自己构建http请求。然后就像是调用自身工程的方法调用,
		而感觉不到是调用远程方法,使得编写客户端变得非常容易

四.负载均衡

	Feign中本身已经集成了Ribbon依赖和自动配置,因此我们不需要额外引入依赖,也不需要再注册RestTemplate 对象。
另外,我们可以像上节课中讲的那样去配置Ribbon,可以通过 ribbon.xx 来进行全局配置。
也可以通过 服务名.ribbon.xx 来对指定服务配置:启动两个 shop_service_product ,重新测试可以发现使用Ribbon的轮询策略进行负载均衡

五.服务调用Feign高级

1. Feign的配置从Spring Cloud Edgware开始,Feign支持使用属性自定义Feign。对于一个指定名称的Feign Client(例如该Feign Client的名称为 feignName ),Feign支持如下配置项:

feign:
  client:
    config:
      feignName: ##定义FeginClient的名称
      connectTimeout: 5000 # 相当于Request.Options
      readTimeout: 5000 # 相当于Request.Options
      # 配置Feign的日志级别,相当于代码配置方式中的Logger
      loggerLevel: full
      # Feign的错误解码器,相当于代码配置方式中的ErrorDecoder
      errorDecoder: com.example.SimpleErrorDecoder
      # 配置重试,相当于代码配置方式中的Retryer
      retryer: com.example.SimpleRetryer
      # 配置拦截器,相当于代码配置方式中的RequestInterceptor
      requestInterceptors:
        - com.example.FooRequestInterceptor
        - com.example.BarRequestInterceptor
      decode404: false
  • feignName:FeginClient的名称
  • connectTimeout : 建立链接的超时时长
  • readTimeout : 读取超时时长
  • loggerLevel: Fegin的日志级别
  • errorDecoder :Feign的错误解码器
  • retryer : 配置重试
  • requestInterceptors : 添加请求拦截器
  • decode404 : 配置熔断不处理404异常

2.请求压缩
Spring Cloud Feign 支持对请求和响应进行GZIP压缩,以减少通信过程中的性能损耗。通过下面的参数即可开启请求与响应的压缩功能:

feign:
  compression:
    request:
      enabled: true # 开启请求压缩
    response:
      enabled: true # 开启响应压缩

同时,我们也可以对请求的数据类型,以及触发压缩的大小下限进行设置:

feign:
  compression:
    request:
      enabled: true # 开启请求压缩
      mime-types: text/html,application/xml,application/json # 设置压缩的数据类型
      min-request-size: 2048 # 设置触发压缩的大小下限

注:上面的数据类型、压缩大小下限均为默认值。
3.日志级别
在开发或者运行阶段往往希望看到Feign请求过程的日志记录,默认情况下Feign的日志是没有开启的。要想用属性配置方式来达到日志效果,只需在 application.yml 中添加如下内容即可:

feign:
  client:
  config:
    shop-service-product:
      loggerLevel: FULL
logging:
  level:
    cn.itcast.order.fegin.ProductFeginClient: debug
  • logging.level.xx : debug : Feign日志只会对日志级别为debug的做出响应
  • feign.client.config.shop-service-product.loggerLevel :配置Feign的 日志Feign有四种
    日志级别:
    • NONE【性能最佳,适用于生产】:不记录任何日志(默认值)
    • BASIC【适用于生产环境追踪问题】:仅记录请求方法、URL、响应状态代码以及执行时间
    • HEADERS:记录BASIC级别的基础上,记录请求和响应的header。
    • FULL【比较适用于开发及测试环境定位问题】:记录请求和响应的header、body和元数
      据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值