All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aliyun.datahub.common.util.RetryUtil Maven / Gradle / Ivy

There is a newer version: 2.25.6
Show newest version
package com.aliyun.datahub.common.util;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.concurrent.*;

public class RetryUtil {
    private static final Logger LOG = LoggerFactory.getLogger(RetryUtil.class);

    private static final long MAX_SLEEP_MILLISECOND = 256 * 1000;

    public static  T executeWithRetry(Callable callable, int retryTimes, long sleepTimeInMilliSecond,
                                         boolean exponential) throws Exception {
        Retry retry = new Retry();
        return retry.doRetry(callable, retryTimes, sleepTimeInMilliSecond, exponential);
    }

    private static class Retry {
        public  T doRetry(Callable callable, int retryTimes, long sleepTimeInMilliSecond,
                             boolean exponential) throws Exception {
            if (null == callable) {
                throw new IllegalArgumentException("Callable!");
            }
            if (retryTimes < 0) {
                throw new IllegalArgumentException(String.format(
                        "retryTime[%d]!", retryTimes));
            }

            Exception saveException = null;
            for (int i = 0; i <= retryTimes; i++) {
                try {
                    return call(callable);
                } catch (Exception e) {
                    LOG.error("Exception when calling callable, " + (i + 1) + "ErrMsg:" + e.getMessage());
                    saveException = e;
                    if (i + 1 < retryTimes && sleepTimeInMilliSecond > 0) {
                        long timeToSleep;
                        if (exponential) {
                            timeToSleep = sleepTimeInMilliSecond * (long) Math.pow(2, i);
                            if (timeToSleep >= MAX_SLEEP_MILLISECOND) {
                                timeToSleep = MAX_SLEEP_MILLISECOND;
                            }
                        } else {
                            timeToSleep = sleepTimeInMilliSecond;
                            if (timeToSleep >= MAX_SLEEP_MILLISECOND) {
                                timeToSleep = MAX_SLEEP_MILLISECOND;
                            }
                        }

                        try {
                            Thread.sleep(timeToSleep);
                        } catch (InterruptedException ignored) {
                        }
                    }
                }
            }
            throw saveException;
        }

        protected  T call(Callable callable) throws Exception {
            return callable.call();
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy