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

相关推荐
Code季风12 分钟前
从超卖到数据一致:分布式锁的最佳实践与演进历程
分布式·微服务·go
Code季风13 分钟前
深入理解 Redis 分布式锁:实现互斥保障的最佳实践
redis·分布式·微服务
一只鹿鹿鹿4 小时前
【网络安全】等级保护2.0解决方案
运维·安全·web安全·架构·信息化
zandy10116 小时前
解构衡石嵌入式BI:统一语义层与API网关的原子化封装架构
架构
你我约定有三11 小时前
分布式微服务--万字详解 微服务的各种负载均衡全场景以注意点
java·开发语言·windows·分布式·微服务·架构·负载均衡
77qqqiqi13 小时前
解决Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are required报错问题
java·数据库·微服务·mybatis·mybatisplus
wydxry13 小时前
MOE架构详解:原理、应用与PyTorch实现
人工智能·pytorch·架构
Goboy13 小时前
Java 使用 FileOutputStream 写 Excel 文件不落盘?
后端·面试·架构
Dragon online13 小时前
数据仓库深度探索系列:架构选择与体系构建
大数据·数据仓库·分布式·架构·spark·大数据架构·数仓架构
Goboy13 小时前
讲了八百遍,你还是没有理解CAS
后端·面试·架构