IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> OpenFeign+hystrix服务降级简单实现 -> 正文阅读

[Java知识库]OpenFeign+hystrix服务降级简单实现

在SpringCloud中,使用OpenFeign实现微服务模块之间的方法调用。假设业务有:微服务A调用微服务B中的某一个接口,并对接口返回的数据作为输出。
问题:由于某些原因这个调用过程不太顺利,比如:连接超时;或者一些其他的原因导致调用失败。对于调用失败的情况,需要一个兜底的解决方案。

微服务B的接口:

@GetMapping("/getTestInfo")
public R<?> queryTestInfo(String username,String password){
...
}

微服务A【名称:module-A】对微服务B【名称:module-B】接口调用:
①在微服务A启动类添加注解:@EnableFeignClients

@EnableFeignClients
@SpringBootApplication(scanBasePackages = {"xxx", "xxx"})
public class XXXApplication{...}

②创建service接口类:
创建一个专门的service接口类,该类的接口格式与将要调用的微服务B的接口格式类似。
在接口类添加注解@Component将其配置为组件,@FeignClient表明为服务调用端。

@Component
@FeignClient(contextId = "remoteTestService", value = "module-B", path = "/xxx", fallbackFactory = RemoteTestFallbackFactory.class,
        url = "http://XXXX")
public interface TestService{
	@GetMapping("/getTestInfo")
	public R<?> queryTestInfo(@RequestParam String username,@RequestParan String password);
}

其中配置项:
value:指定被调用服务模块名称,与微服务B在服务注册中心的名称对应。
path:定义当前FeignClient的统一前缀,一般是在网关路由中配置的匹配路径。
url:指定被调用服务模块所部署的ip地址。一般用于本地调试,配置该项后,从指定ip获取服务,而非服务注册中心获取。

③创建一个FallbackFacory的实现类

public class RemoteTestFallbackFactory implements FallbackFactory<TestService> {

    @Override
    public TestService create(Throwable throwable) {
        log.error("Call remote test service error[{}]", throwable.getMessage());
        return new TestService() {
            @Override
            public R<?> queryTestInfo(String username, String password) {
   				return R.fail("获取测试信息失败:"+throwable.getMessage());
            }
        };
    }
}

问题:
在调用时,可能存在超时情况:
在application.yml设置

#开启hystrix熔断机制
feign:
  hystrix:
    enabled: true
#设置openfeign超时时间,由于OpenFeign封装了Ribbon依赖,实质是设置Ribbon超时时间。
ribbon:
  ReadTimeout: 10000  #建立连接后从服务器读取到可用资源所用的时间
  ConnectTimeout: 10000
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-04-14 23:36:51  更:2022-04-14 23:41:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 4:48:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码