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

相关推荐
爬山算法17 分钟前
Hibernate(74)如何在CQRS架构中使用Hibernate?
java·架构·hibernate
香芋Yu1 小时前
【大模型教程——第二部分:Transformer架构揭秘】第2章:模型家族谱系:从编码器到解码器 (Model Architectures)
深度学习·架构·transformer
像少年啦飞驰点、2 小时前
零基础入门 Spring Boot:从“Hello World”到可部署微服务的完整学习路径
java·spring boot·微服务·编程入门·后端开发
从此不归路2 小时前
Qt5 进阶【13】桌面 Qt 项目架构设计:从 MVC/MVVM 到模块划分
开发语言·c++·qt·架构·mvc
java干货2 小时前
微服务:把一个简单的问题,拆成 100 个网络问题
网络·微服务·架构
indexsunny3 小时前
互联网大厂Java求职面试实战:Spring Boot微服务与Kafka消息队列应用解析
java·数据库·spring boot·微服务·面试·kafka·jpa
天才奇男子4 小时前
《深度解析HAProxy七层代理:原理、配置与最佳实践》
linux·运维·微服务·云原生
橙露5 小时前
Vue3+Pinia实战:从零搭建企业级后台管理系统的核心架构
架构
onkel in blog5 小时前
【Java】Gradle 多模块项目实战:Spring Boot 微服务搭建全流程
java·spring boot·微服务·gradle
七夜zippoe5 小时前
Kubernetes与Python微服务编排实战:从基础部署到自动扩缩容
python·微服务·kubernetes·service·hpa