java调用服务出错时重试


1、问题

        由于调用的服务在出错时正常返回,返回的数据里包含Server Error,并没有包含其他有效信息,导致OkHttp 认为结果正常,拦截器里不能自动进行重试,因此需要自己写重试逻辑。

2、递归重试

	@Test
    public void retryRecursion() {
        //重试5次
        String result = retryRecursion(5);
        System.out.println(result);
    }
private static String retryRecursion(int times) {

        try {
            String result = okHttpClientUtils.doPost(url, request);
            if (result.contains("Server Error")) {
                throw new IOException(result);
            }
            return result;
        } catch (Exception e) {
            //重试次数到了
            if (--times <= 0) {
                logger.error("服务出错, url: {}, request: {}, error: {}", url, request, e);
                return "";
            }
            //休眠一会
            try {
                TimeUnit.MILLISECONDS.sleep(50);
            } catch (InterruptedException e1) {
            }
            //重试
            return retryRecursion(times);
        }
    }

3、while 重试

 	@Test
    public void retryWhile() {
        //重试5次
        String result = retryWhile(5);
        System.out.println(result);
    }
private String retryWhile(int times) {
        String result = "";
        boolean first = true;
        while (first || (times > 0 && StringUtils.isBlank(result))) {
            first = false;
            try {
                result = okHttpClientUtils.doPost(url, request);
                if (result.contains("Server Error")) {
                    throw new IOException(result);
                }
                return result;
            } catch (Exception e) {
                //重试次数到了
                if (--times <= 0) {
                    logger.error("服务出错, url: {}, request: {}, error: {}", url, request, e);
                    return "";
                }
                //休眠一会
                try {
                    TimeUnit.MILLISECONDS.sleep(50);
                } catch (InterruptedException e1) {
                }
            }
        }
        return result;
    }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_lrs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值