SpringCloud之feign

feign的使用

    • 一、概述
    • 二、feign的使用流程
      • [2.1 在pom文件中添加依赖](#2.1 在pom文件中添加依赖)
      • [2.2 feign的配置](#2.2 feign的配置)
        • [2.2.1 修改日志级别](#2.2.1 修改日志级别)
          • [2.2.1.1 在yml中配置](#2.2.1.1 在yml中配置)
          • [2.2.1.2 在代码中写配置类](#2.2.1.2 在代码中写配置类)
        • [2.2.2 响应结果解析器](#2.2.2 响应结果解析器)
        • [2.2.3 请求参数编码](#2.2.3 请求参数编码)
        • [2.2.4 支持的注解格式](#2.2.4 支持的注解格式)
        • [2.2.5 失败的重试机制](#2.2.5 失败的重试机制)
      • [2.3 Nacos支持Feign,可以直接在接口基础上实现负载均衡效果](#2.3 Nacos支持Feign,可以直接在接口基础上实现负载均衡效果)

一、概述

Feign是一个声明式HTTP客户端,它使HTTP API请求变得更简单和更优雅。它基于注解,在创建动态代理时解析接口方法,并将其映射到HTTP请求。我们只需要编写Java接口并添加注解,就可以轻松地使用Feign处理HTTP请求。

SpringCloud对Feign进行了增强,使Feign支持了SpringMVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。

Feign还提供了可插拔的编码器和解码器,以将Java对象转换为HTTP请求、响应和错误

二、feign的使用流程

2.1 在pom文件中添加依赖

当模块A要调用模块B的方法时,要在调用者中加入Feign的依赖,要在调用者的启动类上添加注解 @EnableFeignClients

java 复制代码
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

2.2 feign的配置

2.2.1 修改日志级别

feign.Logger.Level : 包含四种不同的级别:NONE、BASIC、HEADERS、FULL

java 复制代码
NONE:没有任何日志,也是默认配置;

BASIC:可以记录http请求什么时候发送,什么时候结束,耗时多久等基本信息;

HEADERS:除了BASIC中含有的以外,还包含请求头和响应头; 

FULL:是最全面的,除了HEADERS中包含的以外,还包含请求体信息和响应体信息。
2.2.1.1 在yml中配置
java 复制代码
feign:  
  client:
    config: 
      userservice: # 针对某个微服务的配置
      #default: # 这里用default就是全局配置,如果是写服务名称,则是针对某个微服务的配置
        loggerLevel: FULL #  日志级别 
2.2.1.2 在代码中写配置类
java 复制代码
public class DefaultFeignConfiguration {
    @Bean
    public Logger.Level logLevel(){
        return Logger.Level.BASIC;
    }
}

想要局部生效时,就在Feign的具体的接口上的注解上添加configuration = FeignConfiguration.class

java 复制代码
@FeignClient(value = "userservice",configuration = DefaultFeignConfiguration.class)
public interface TopoClient {
  /**
     * 获取关联拓扑
     * @param param
     * @return
     */
    @PostMapping("/api/topo/cmnet/getSerchCmNetTopo")
    public BTopo getSerchCmNetTopo(@RequestBody QueryRelParam param);
}

全局生效,在启动类添加EnableFeignClients注解 设置defaultConfiguration 属性;如果只有一个client可以使用clients=类.class,如果多个可以直接扫包

java 复制代码
@EnableFeignClients(basePackages = {"com.softwaregroup.communication.topo"}, defaultConfiguration = DefaultFeignConfiguration.class)
2.2.2 响应结果解析器

feign.codec.Decoder: http远程调用的结果做解析,例如解析json字符串为java对象

2.2.3 请求参数编码

feign.codec.Encoder: 将请求参数编码,便于通过http请求发送

2.2.4 支持的注解格式

feign. Contract : 默认是SpringMVC的注解

2.2.5 失败的重试机制

feign. Retryer : 请求失败的重试机制,默认是没有,不过会使用Ribbon的重试

2.3 Nacos支持Feign,可以直接在接口基础上实现负载均衡效果

微服务名称:nrms-topo-ip

启动项目主类

java 复制代码
@SpringCloudApplication
@EnableDiscoveryClient
@EnableFeignClients(basePackages = {"com.softwaregroup.communication.topo"})

@Slf4j
public class TopoDataPluginDataNetwork {
}

CmNetClientFeign

java 复制代码
@FeignClient(name = "nrms-topo-cmnet",
        configuration = FeignClientsConfiguration.class)
public interface CmNetClientFeign {

    /**
     * 获取关联拓扑
     * @param param
     * @return
     */
    @PostMapping("/api/topo/getSerchTopo")
    public BTopo getSerchTopo(@RequestBody QueryRelParam param);
    }

注意!

因为我们大部分项目都需要进行权限认证,当接口调用别的微服务接口时,也需要把请求头传过去可以通过Interceptor(拦截器)实现

java 复制代码
/**
 * @author:  zhang
 * @date:  Created in 2024/7/9 20:24
 * 文件说明:  <p>Feign 调用增强请求头,防止登录信息无法传递而被服务拦截
 */
@Component
public class FeignInterceptor implements RequestInterceptor {
    @Override
    public void apply(RequestTemplate requestTemplate) {
        //获取客户端访问的请求
        ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        if(requestAttributes != null){
            HttpServletRequest request = requestAttributes.getRequest();
            if (request != null) {
                String cookie = request.getHeader("Cookie");
                String token = request.getHeader("Authorization");

                //同步到 feign 请求中
                requestTemplate.header("Cookie", cookie);
                requestTemplate.header("Authorization", token);
                return;
            }
        }
    }
}

调用CmNetClientFeign 接口

java 复制代码
在控制层中引入cmNetClientFeign便可以直接通过cmNetClientFeign调用另一个微服务的接口
  @Resource
    private CmNetClientFeign cmNetClientFeign;

具体实现控制层

该微服务名:nrms-topo-cmnet

java 复制代码
@RestController
@RequestMapping("/api")
@Slf4j
public class CmNetController {
 @PostMapping("/topo/getSerchTopo")
    public BTopo getSerchCmNetTopo(@RequestBody QueryRelParam param) {
        return cmNetService.getSerchCmNetTopo(param);
    }
}
相关推荐
chanalbert18 小时前
Nacos 技术研究文档(基于 Nacos 3)
spring boot·分布式·spring cloud
chanalbert18 小时前
Spring Cloud分布式配置中心:架构设计与技术实践
spring boot·spring·spring cloud
追风少年浪子彦1 天前
mapstruct与lombok冲突原因及解决方案
java·spring boot·spring·spring cloud
今天又在摸鱼1 天前
SpringCloud
java·spring cloud
灰小猿2 天前
多级@JsonTypeInfo和@JsonSubTypes注解使用详解及场景分析
java·后端·mysql·spring·spring cloud
lwb_01182 天前
【springcloud】快速搭建一套分布式服务springcloudalibaba(四)
后端·spring·spring cloud
麦兜*3 天前
Spring Boot 集成Reactive Web 性能优化全栈技术方案,包含底层原理、压测方法论、参数调优
java·前端·spring boot·spring·spring cloud·性能优化·maven
洁辉4 天前
Spring Cloud 全栈指南:构建云原生微服务的终极武器
spring cloud·微服务·云原生
roc_lab4 天前
Spring Cloud Feign默认不支持重定向解决方案
spring cloud
重生之后端学习5 天前
day08-Elasticsearch
后端·elasticsearch·spring cloud·中间件·全文检索·jenkins