Springboot中Feign client调用时版本问题

现有Springboot项目三个,分别为jpmc-adapter, gsdic-api, twpre-api。gsdic-api, twpre-api是公共的服务,对外提供Restful的API,通过feign client去调用。

大的背景就是,jpmc-adapter现在需要调用另外两个公共的服务。

Springboot版本:

jpmc-adapter           1.5.9

gsdic-api                   1.5.9

twpre-api                  2.0.5

可以看到jpmc-adaper和gsdic-api的Springboot版本是一致的。如果jpmc-adaper通过feign client单单调用 gsdic-api,一切都OK!

现在的情况是:jpmc-adaper既需要调用 gsdic-api,又需要调用twpre-api,然后启动项目的时候就报错了,错误如下:

这是Springboot版本不一致导致的问题。

先看jpmc-adaper中是如何去调用另外两个服务的。大致如下:

1. build.gradle中引入另外两个公共服务的jar包。

2. gradle.properties中统一管理依赖版本号,如下:

3. 启动类中引入公共服务的配置:

4. 测试类中调用如下:

其中,twpre-api的FeignClient是来自org.springframework.cloud.openfeign.FeignClient;如下:

而gsdic-api的FeignClient是来自org.springframework.cloud.netflix.feign.FeignClient, 如下:

解决办法如下:

你可以把所以服务的版本换成一致,这样就能避免此类问题。但是换版本可能会导致很多问题,这里可以通过如下方式解决:

因为jpmc-adapter和gsdic-api的版本是一致的,那么我们在调用方即jpmc-adapter中重写twpre-api的FeignClient。

package com.geoswift.jpmc.api;

import org.springframework.cloud.netflix.feign.FeignClient;

import com.geoswift.twpre.fapi.TwpreRestAPI;

@FeignClient(name="twpre", path="/api/twpre/v1")
public interface MyTwpreRestAPI extends TwpreRestAPI {
	
}

然后在测试的时候使用我们重写后的客户端就行了,如下:

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot Feign是一个基于RestTemplate的声明式Web Service客户端,它简化了微服务之间的远程调用Feign通过注解方式定义接口,内部封装了负载均衡和服务熔断的功能,提供了一种更简洁、更方便的方式进行服务之间的通信。 熔断机制是一种保护机制,用于防止由于服务不可用或无法正常响应而导致的服务雪崩效应。假设某个微服务在高峰期间不可用,当其他微服务不断向该服务发送请求,由于无法得到正常的响应,会占用大量的线程和资源,最终导致整个系统崩溃。为了解决这个问题,可以使用熔断器。 熔断器是Feign的一种机制,用于处理服务调用失败或超的情况。当服务调用或出现错误,熔断器会暂断对该服务的调用,并返回给客户端一个预先定义的默认值或错误信息,而不是一直等待响应。这样可以保护系统不受故障服务的影响,提高系统的可用性和稳定性。 在Spring Boot使用Feign进行服务调用熔断的具体步骤如下: 1. 在使用Feign的微服务项目引入相应的依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 2. 创建Feign接口,并使用@FeignClient注解指定要调用的微服务的名称: ```java @FeignClient(value = "service-name", fallback = ServiceFallback.class) public interface ServiceClient { @GetMapping("/api/path") String invokeService(); } ``` 3. 实现熔断的回退逻辑,创建一个Fallback类,实现Feign接口并定义相应的错误处理方法: ```java @Component public class ServiceFallback implements ServiceClient { @Override public String invokeService() { return "Fallback message"; } } ``` 4. 在应用主类上添加@EnableFeignClients注解启用Feign和熔断功能: ```java @SpringBootApplication @EnableFeignClients public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 通过以上步骤,当微服务调用或出现错误Feign会自动调用相应的熔断器回退逻辑并返回默认值,确保系统的稳定性。可以根据实际情况自定义熔断处理逻辑,比如记录日志、发送警报等操作,以便及处理故障。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值