okhttp3 自定义超时重试

需求描述

对一个url地址发起请求后,设置超时时长为3秒,若超时时重试3次后仍然超时视为宕机并返回自定义的code信息。

解决

这是我入职公司的第一个任务,上级说简单,不过我搞了有两天了,因为在网上搜的自定义超时重试次数看不懂。。后来还是问强哥,他给了我一篇博客链接,然后我才有了思路。

  1. 发起post请求
	        OkHttpClient client = new OkHttpClient
                .Builder()
                .connectTimeout(okhttpTimeOut, TimeUnit.SECONDS) // 设置超时时长,单位秒
                .addInterceptor(new OkhttpInterceptor(maxRetry)) //过滤器,设置最大重试次数
                .retryOnConnectionFailure(false) //不自动重连
                .build();

  1. 过滤器,通过递归达到超时重试的目的

    这里需要说明:原本以为超时后直接拿到response可以判断超时信息,简简单单做个循环就好。但是!超时后直接抛出异常 ConnectException,我原来的笨方法就是捕获这个异常,3次重试就做三层的try catch,代码写出来傻傻的。

    还好,递归可以解决这个问题,本质上没什么变化,但是用上了递归就是爽!

@Slf4j
class OkhttpInterceptor implements Interceptor{

    private int maxRentry;// 最大重试次数

    public OkhttpInterceptor(int maxRentry){
        this.maxRentry=maxRentry;
    }

    @NotNull
    @Override
    public Response intercept(@NotNull Chain chain) throws IOException {
        /* 递归 4次下发请求,如果仍然失败 则返回 null ,但是 intercept must not return null.
         * 返回 null 会报 IllegalStateException 异常
         * */
        return retry(chain,0);//这个递归真的很🐂
    }
    Response retry(Chain chain,int retryCent){
        Request request = chain.request();
        Response response =  null;
        try{
            log.info("messageId: "+messageId+"  第"+(retryCent+1)+"次执行下发NEF请求.");
            response = chain.proceed(request);
        }catch (Exception e){
            if ( maxRentry > retryCent ){
                return retry(chain,retryCent+1);
            }
        }finally {
            return response;
        }
    }
}
  1. 执行请求,捕获IllegalStateException异常
try{
    response = client.newCall(request).execute();//执行请求
    /*如果response可以正常返回,说明能连接上,接着写业务逻辑即可*/
}catch(IllegalStateException e){
    //捕获异常,intercept must not return null.过滤器不能返回null
            e.printStackTrace();
            log.info("重试3次后访问超时.");
            resMap.put("code","404");//在这里可以自定义返回信息
            return resMap;
}
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值