java降级实现_Hystrix 服务降级-后备模式 实现思路

本文介绍了如何使用Hystrix在Java中实现服务降级,特别是在服务调用失败时,通过执行后备策略提供用户体验。通过示例代码详细展示了HystrixCommand的使用,包括设置超时时间、run方法执行核心业务和getFallback方法实现后备逻辑。此外,还对比分析了一个自定义线程池和Future的简单降级实现。
摘要由CSDN通过智能技术生成

服务降级

Hystrix 提供了服务降级功能。

有些场景下当调用服务失败时,不应该产生一个Exception 异常给用户。而是采用执行备用策略。

比如:假如一个购物网站,它可以监控用户的行为,并尝试向用户推荐其它可以购买的商品。通常来说,可以调用微服务来对用户过去的行为进行分析,并返回针对特定用户的推荐列表。但是如果调用这个服务失败。则启动后备策略来检索一个更通用的偏好列表,该列表可以是热门商品的列表或基于全部用户购买记录分析的结果。

Hystrix 服务降级示例package com.jijs.fallback.test;import java.util.concurrent.TimeUnit;import com.netflix.hystrix.HystrixCommand;import com.netflix.hystrix.HystrixCommandGroupKey;import com.netflix.hystrix.HystrixCommandProperties;public class HystrixFallbackDemo extends HystrixCommand {    protected HystrixFallbackDemo() {        super(Setter.withGroupKey(

HystrixCommandGroupKey.Factory.asKey("HystrixFallback"))

.andCommandPropertiesDefaults(

HystrixCommandProperties.Setter()

.withExecutionTimeoutInMilliseconds(1000)));

}    @Override

protected String run() throws Exception {        //执行超时

TimeUnit.MILLISECONDS.sleep(2000);        //执行异常

//int i = 5 / 0;

//主动抛出异常

//throw new HystrixTimeoutException();

return "ok";

}    @Override

protected String getFallback() {        return "fallback";

}

public static void main(String[] args) {

HystrixFallbackDemo t = new HystrixFallbackDemo();

String result = t.execute();

System.out.println(result);

}

}

使用 Hystrix 实现一个后备策略,开发人员必须以下做几点。

1、继承 HystrixCommand 类。

2、在构造中定义 Hystrix 相关策略

3、重写 HystrixCommand 类的 run() 方法,写自己的核心业务。

4、重写 HystrixCommand 类的 getFallback() 方法,来实现后备策略。

使用 HystrixCommandProperties.Setter().withExecutionTimeoutInMilliseconds(1000)  设置调用执行 run() 方法的超时时间为1秒。

当执行 run() 方法时间超过1秒、执行run报错 或 抛出异常都会执行 getFallback () 方法。

自己动手实现 Hystrix 的后备策略package com.jijs.fallback.test;import java.util.concurrent.Callable;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.Future;import java.util.concurrent.TimeUnit;public class FallbackDemo {    public static void main(String[] args) {

ExecutorService executor = Executors.newSingleThreadExecutor();

Task task = new Task();

Future f = executor.submit(task);

String result;        try {

result = f.get(1000, TimeUnit.MILLISECONDS);    //执行超时时间1000

} catch (Exception e) {            //捕获所有的 Exception 异常,都执行 fallback方法。

result = task.fallback();

}

System.out.println(result);

executor.shutdown();

}

}class Task implements Callable {    public String call() throws Exception {        //执行超时

TimeUnit.MILLISECONDS.sleep(2000);        //执行异常

//int i = 5 / 0;

//主动抛出异常

//throw new HystrixTimeoutException();

return "ok";

}    //后备方法

public String fallback() {        return "fallback";

}

}

1、Hystrix 底层默认也是使用线程池来隔离不同的资源的。这里我们也模拟创建一个线程池。

2、然后将任务提交给线程池执行,因为任务实现了Callable 接口,所有我们可以使用 Future 来异步获取执行结果。

3、通过 Future.get(2000, TimeUnit.MILLISECONDS) 来指定 任务 执行的超时时间。

4、捕获异常,如果出现Exception的异常都执行 Task 的后备方法 fallback()。

从功能上来看,我们已经简单的实现了

作者:jijs

链接:https://www.jianshu.com/p/ac5f87a79538

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值