山东大学软件学院项目实训-创新实训-基于大模型的旅游平台(二十四)- 微服务(4)

目录

[8. http客户端Feign](#8. http客户端Feign)

[8.1 feign远程调用](#8.1 feign远程调用)

[8.2 feign自定义配置](#8.2 feign自定义配置)

[8.3 feign性能优化](#8.3 feign性能优化)

[8.4 feign最佳实践](#8.4 feign最佳实践)


8. http客户端Feign

8.1 feign远程调用

RestTemplate存在的问题 :

  1. 代码可读性差

  2. 参数复杂URL难以维护

Feign是声明式的http客户端

使用步骤 :

  1. 引入依赖
复制代码
  
          <!--Feign客户端依赖-->
          <dependency>
              <groupId>org.springframework.cloud</groupId>
              <artifactId>spring-cloud-starter-openfeign</artifactId>
          </dependency>
  1. 开启自动装配 在启动类上添加注解
复制代码
  
  @EnableFeignClients
  1. 创建接口声明
复制代码
  
  @FeignClient("userservice")
  public interface UserClient {
      
      @GetMapping("/user/{id}")
      User findById(@PathVariable Long id);
  }
  1. order- controller中替换原来发请求的代码
复制代码
  
     @Autowired
     private OrderMapper orderMapper;
  ​
      // 注入feign接口
      @Autowired
      private UserClient userClient;
  ​
      @GetMapping("{orderId}")
      public Order queryOrderByUserId(@PathVariable("orderId") Long orderId) {
          Order order = orderMapper.findById(orderId);
          User user = userClient.findById(order.getUserId());
          order.setUser(user);
          return order;
      }

8.2 feign自定义配置

修改日志级别 :

  1. 配置文件方式 :

全局生效 :

复制代码
  
  feign:
    client:
      config:
        default:     #  default就是全局配置    如果写服务名称就是针对某个微服务的配置
          loggerLevel: FULL  # 日志级别

只针对某个微服务生效

复制代码
  
  feign:
    client:
      config:
        userservice:     # 只对userservice生效
          loggerLevel: FULL  # 日志级别
  1. 代码配置

8.3 feign性能优化

主要包括 :

  1. 使用连接池代替默认的URLCollection

  2. 日志级别,最好用basic或none

连接池配置 ;

引入依赖 :

复制代码
  
          <!--httpClient的依赖-->
          <dependency>
              <groupId>io.github.openfeign</groupId>
              <artifactId>feign-httpclient</artifactId>
          </dependency>

配置连接池 :

复制代码
  
  feign:
    client:
      config:
        default:     #  default就是全局配置    如果写服务名称就是针对某个微服务的配置
          loggerLevel: BASIC  # 日志级别
    httpclient:
      enable: true           #  支持HTTPClient的开关
      max-connection: 200       #   最大连接数
      max-connections-per-route: 50     #  单个路径的最大连接数

8.4 feign最佳实践

方式一 :

方式二 :

方式二的实现 :

  1. 新建feign-api模块 引入feign的stater的依赖

  2. 把order-service的 UserClient User实体类 FeignConfiguration配置类

  3. 复制到feign-api模块中

  4. 在order-service中引入feign-api模块的依赖

  5. 测试

相关推荐
布列瑟农的星空3 分钟前
大话设计模式——关注点分离原则下的事件处理
前端·后端·架构
Aileen_0v01 小时前
【分布式系统架构全解析:从单机到微服务,Redis如何成为性能加速器?】
redis·微服务·云原生·架构
Wgllss2 小时前
完整烟花效果,Compose + 协程 + Flow + Channel 轻松实现
android·架构·android jetpack
程序猿阿伟3 小时前
《支付回调状态异常的溯源与架构级修复》
后端·架构
SmalBox3 小时前
【渲染流水线】[逐片元阶段]-[深度写入]以UnityURP为例
架构
猿java4 小时前
Elasticsearch有哪几种分页方式?该如何选择?
后端·elasticsearch·架构
K神5 小时前
Spring Cloud Gateway+Redis+Nacos之动态路由和负载均衡
后端·微服务
数据智能老司机6 小时前
探索Java 全新的线程模型——结构化并发
java·性能优化·架构
数据智能老司机6 小时前
探索Java 全新的线程模型——作用域值
java·性能优化·架构
数据智能老司机6 小时前
探索Java 全新的线程模型——并发模式
java·性能优化·架构