山东大学软件学院项目实训-创新实训-基于大模型的旅游平台(二十四)- 微服务(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. 测试

相关推荐
数据要素X8 小时前
寻梦数据空间 | 架构篇:从概念到落地的技术实践与突破性创新
大数据·运维·数据仓库·微服务·数据治理·数据中台·可信数据空间
法欧特斯卡雷特8 小时前
从 Kotlin 编译器 API 的变化开始: 2.2.2X -> 2.3.0-Beta1
后端·架构·开源
Light6011 小时前
领码方案|微服务与SOA的世纪对话(6):组织跃迁——智能架构下的团队与文化变革
微服务·云原生·ddd边界·组织双生体·pod协同·文化仪式·ai自演进
柳贯一(逆流河版)11 小时前
Nacos 实战指南:微服务下服务注册与配置管理的完整落地
java·微服务·架构
一叶飘零_sweeeet11 小时前
从 “黑盒“ 到 “透明“:SkyWalking 实战指南 —— 让微服务问题无所遁形
分布式·微服务·skywalking·分布式链路追踪
盗德11 小时前
为什么要用Monorepo管理前端项目?(详解)
前端·架构·代码规范
koddnty13 小时前
协程退出与智能指针
后端·架构
yuzhiboyouye15 小时前
前端架构师,是架构什么
前端·架构
用户939509544139916 小时前
全开源点餐系统源码全解析:从架构设计到部署实践的完整指南
架构
数据智能老司机16 小时前
数据工程设计模式——数据基础
大数据·设计模式·架构