• 5. 微服务之基于Feign的远程调用


    5.1 RestTemplate 方式调用存在的问题

    以前利用 RestTemplate 发起远程调用

    String url = "http://user-service/user/" + order.getUserId();
    User user = restTemplate.getForObject(url,User.class);
    
    • 1
    • 2

    存在的问题:

    • 代码可读性差,编程体验不统一
    • 参数复杂URL难以维护
    5.2 Feign 的介绍

    Feign 是一个声明式的http客户端,其作用就是帮助我们优雅的实现http请求的发送,解决上面提到的问题

    5.3 Feign 的使用步骤

    在服务模块的 pom.xml 引入依赖

    <dependency>
        <groupId>org.springframework.cloudgroupId>
        <artifactId>spring-cloud-starter-openfeignartifactId>
    dependency>
    
    • 1
    • 2
    • 3
    • 4

    在启动类添加注解 @EnableFeignClients 开启Feign功能

    @EnableFeignClients //开启Feign功能
    @MapperScan("cn.itcast.order.mapper") //扫描包,配置接口实现类
    @SpringBootApplication
    public class OrderApplication {
        public static void main(String[] args) {
            SpringApplication.run(OrderApplication.class, args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    建立服务提供者接口,远程调用服务

    @FeignClient("user-service") // 服务名
    public interface UserClient {
        @GetMapping("/user/{id}") // 路径
        User findById(@PathVariable("id") Long id);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    主要是基于SpringMVC的注解来声明远程调用信息,比如:
    服务名称:user-service
    请求方式:GET
    请求路径:/user/{id}
    请求参数:Long id
    返回值类型:User

    最后通过自动注入对象来调用该接口的方法

    5.4 Feign 的自定义配置

    在这里插入图片描述
    一般只需要修改日志配置,日志默认级别为 NONE,修改级别:

    方式一:配置文件方式

    全局生效

    feign:
      client:
        config:
          default: # 这里用default就是全局配置
            loggerLevel: HEADERS # 日志级别
    
    • 1
    • 2
    • 3
    • 4
    • 5

    局部生效

    feign:
      client:
        config:
          user-service: # 写服务名称,则是针对某个微服务的配置
            loggerLevel: HEADERS # 日志级别
    
    • 1
    • 2
    • 3
    • 4
    • 5
    方式二:Java代码方式,需要先声明一个Bean

    创建一个Feign的配置类

    public class FeignClientConfiguration {
        @Bean
        public Logger.Level feignLogLevel() {
            return Logger.Level.BASIC;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    全局配置,将配置类放入注解 @EnableFeignClients 中

    @EnableFeignClients(defaultConfiguration = FeignClientConfiguration.class)
    
    • 1

    局部配置,将配置类放入注解

    @FeignClient(value = "user-service",configuration = FeignClientConfiguration.class)
    
    • 1

    日志级别越高,对性能影响越大

    5.5 Feign 的性能优化

    Feign 底层的客户端实现:

    • URLConnection:默认实现,不支持连接池
    • Apache HttpClient:支持连接池
    • OKHttp:支持连接池

    因此优化Feign的性能包括:

    1. 使用连接池代替默认的URLConnection
    2. 日志级别,最好用basic或none
    连接池配置:

    引入依赖:

    <dependency>
       <groupId>io.github.openfeigngroupId>
       <artifactId>feign-httpclientartifactId>
    dependency>
    
    • 1
    • 2
    • 3
    • 4

    配置连接池:

    feign:
      client:
        config:
          user-service:
            # Feign日志级别修改
            loggerLevel: BASIC
      httpclient:
        enabled: true # 开启feign对HttpClient的支持
        max-connections: 200 # 最大连接数
        max-connections-per-route: 50 # 每个路径的最大连接数
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    5.6 实现Feign的最佳实践

    若有多个服务想调用同一个功能模块时,每个服务都要写一次相同的调用请求,造成代码冗杂,这时可以创建一个专门的api模块集中管理调用,而各个服务只需要引用该模块就能完成调用了
    在这里插入图片描述

    实现步骤:

    创建一个模块,命名为 feign-api,然后引入Feign的相关依赖

    在这里插入图片描述

    建立好feign远程调用要有的相关配置

    在这里插入图片描述

    在服务消费者模块引入feign-api依赖

    在这里插入图片描述

    注意:调用会报错

    在这里插入图片描述

    自动进行注入时该对象没找到,因为该模块在启动时是扫描自己包下的对象,而 UserClient 是 feign-api 模块包内的,所以扫描不到生成不了对应对象

    解决办法:

    方式一:指定 FeignClient 所在包

    @EnableFeignClients(basePackages = "cn.cyx.feign.client") //开启Feign功能
    
    • 1

    方式二:指定具体类对应的字节码

    @EnableFeignClients(clients = {UserClient.class}) //开启Feign功能
    
    • 1
  • 相关阅读:
    WPF入门教程系列二十八 ——DataGrid使用示例MVVM模式(6)
    一、K近邻算法K-NN(有监督学习)
    负载均衡策略
    如何画好技术图
    记一次beego通过go get命令后找不到bee.exe的坑
    【miniQMT实盘量化3】获取历史行情数据
    2023系统分析师---冲刺资料必备知识点二
    很显然,现在元宇宙、web3.0的关注度,早已超过了区块链
    solidity函数重载以及调用
    Python使用MySQL,无记录则插入,有记录则更新 - ON DUPLICATE KEY UPDATE
  • 原文地址:https://blog.csdn.net/qq_46656580/article/details/127831256