springCloud之openfeign使用入门,Get/Post请求,Feign扩展连接池

引入依赖

使用openfeign肯定要先引入依赖,默认已经引入了springCloud和springCloudAlibaba的依赖了

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

然后在启动类上加上@EnableFeignClients注解
在这里插入图片描述
编写一个feign请求接口,这里要注意,如果项目中还使用了mybatis要注意不要让Mybatis扫描到这里的feign接口了,以免造成代理类的混乱

Post请求Demo
在这里插入图片描述

在需要使用的地方直接注入就可以使用了,这里肯定是使用了jdk动态代理生成了一个代理类,所以这里我直接@Resource注入了,找不到byName后就会去按照byType去注入的

在这里插入图片描述

上面就是feign的简单实用了,下面来进一步了解下

Feign的组成

在这里插入图片描述

自定义Feign的请求日志(代码方式和yml配置方式)针对被调用的单个服务

Feign的接口配置类,不需要加Configuration,不然如果被启动类扫描到的话会出现和Ribbon一样的父子上下文问题,Feign日志配置同样有代码方式和yml配置两种方式

先介绍代码方式

package com.fchen.usercenter.config;

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

public class UserCenterFeignConfiguration {

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

}

然后在定义的Feign接口类里引用Feign的日志配置,这里还要注意一点,就是还需要加上针对这个Feign接口的log模式为debug不然不会生效的
在这里插入图片描述
在这里插入图片描述

yml配置方式
yml配置比较简单,但是还是需要配置Feign接口类配置日志级别为Debug级别上才能使配置生效

logging:
  level:
    com.fchen.usercenter.feignclient.UserCenterFeignClient: debug
feign:
  client:
    config:
      #想要调用的微服务名称
      testHashMap:
        loggerLevel: FULL

在这里插入图片描述

自定义Feign的请求日志(代码方式和yml配置方式)全局配置

这个全局配置要是要基于Feign接口的类的日志模式为debug的前提下才能生效

java代码全局方式

logging:
  level:
    com.fchen.usercenter.feignclient.UserCenterFeignClient: debug

在这里插入图片描述
Feign日志级别定义的java配置类
在这里插入图片描述

在启动类上引入该java配置类
在这里插入图片描述

配置类全局方式
还是配置类舒服

logging:
  level:
    com.fchen.usercenter.feignclient.UserCenterFeignClient: debug
feign:
  client:
    config:
      #将调用的微服务名称改成default就配置成全局的了
      default:
        loggerLevel: FULL

Feign的其余有关配置

在这里插入图片描述

Feign Get/Post请求demo

get请求多个参数使用demo

Feign请求发起
在这里插入图片描述

请求接收
在这里插入图片描述

post请求demo

Feign请求发起
在这里插入图片描述
请求接收
在这里插入图片描述
feign方式的请求头添加参数

public interface RemoteService {
    @Headers({"Content-Type: application/json","Accept: application/json"})
    @RequestLine("GET /users/list")
    User getOwner(User user);
}

Feign的性能简单优化(使用连接池)

在上面Feign的组成中我们可以知道默认的Feign是使用的HttpURLConnection是没有使用连接池的,对于有性能要求的场景这个是很致命的

在这里插入图片描述
使用httpclient连接池时需要引入依赖

<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
</dependency>
feign:
  httpclient:
    # 让feign使用apache httpclient作请求
    enabled: true
    # feign的最大连接数,我这里理解的连接池中的最大可用连接数量
    max-connections: 200
    # feign单个路径的最大连接数,我这里理解的是一个请求url上的最大并发数
    max-connections-per-route: 50

feignribbon同时配置一些参数,比如connectTimeoutreadTimeoutfeign的配置会覆盖掉ribbon

feign:
  client:
    config:
      default:
          connectTimeout: 1000000
          readTimeout: 1200000
  hystrix:
    enabled: true
ribbon:
  eager-load:
      enable: true
      clients: cloud-having
  ConnectTimeout: 150000
  ReadTimeout: 150000
  MaxAutoRetries: 0
  MaxAutoRetriesNextServer: 1
  retryableStatusCodes: 500,502,504
#  retryableStatusCodes: 500,502,504,404
  OkToRetryOnAllOperations: true
  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一个为开发者提供了快速构建分布式系统的工具集,其中非常重要的一部分就是OpenFeignOpenFeign是一个声明式、模板化的HTTP客户端,它可以让开发者更加方便的调用HTTP接口。下面我们来详细了解一下Spring Cloud整合OpenFeign使用方式。 首先,我们需要在pom.xml文件中添加依赖,如下所示: ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>{版本号}</version> </dependency> ``` 然后,我们需要在启动类上添加@EnableFeignClients注解,表示开启Feign客户端自动配置。同时,我们还需要通过@FeignClient注解来定义接口。例如: ``` @FeignClient(name = "user-service") public interface UserFeignClient { @GetMapping("/user/findById") User findById(@RequestParam("id") Long id); } ``` 在上面的代码中,@FeignClient注解中的name属性表示调用的服务名,而接口中的findById方法就是定义的远程调用的接口。其中,@RequestParam注解表示使用@RequestParam方式传参。 最后,我们在业务代码中使用定义的接口即可。例如: ``` @RestController public class UserController { @Autowired private UserFeignClient userFeignClient; @GetMapping("/findUser") public User findUser(Long id) { return userFeignClient.findById(id); } } ``` 通过以上步骤,我们就可以方便地使用OpenFeign来调用HTTP接口,实现微服务之间的远程调用。整合OpenFeign有很多细节需要注意,例如如何处理调用异常、如何配置重试等等。但总体来说,Spring Cloud整合OpenFeign使用起来非常简单,是我们构建分布式系统的重要利器之一。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值