什么是使用BackOffPolicy的“优雅”方法

时间:2012-10-08 01:29:58

标签: java google-drive-api

我偶尔注意到我的Drive SDK调用会定期失败并出现500错误,重试请求通常会立即修复错误。看看谷歌文档,它建议使用指数退避技术,我写了我自己的实现工作正常,但是在调试时碰巧碰到BackOffPolicy接口,经过更多的调查我甚至发现了实现ExponentialBackOffPolicy。

因此,我不想自己管理,而是最好删除我的实现,让SDK为我做。退避策略可以(据我所知)使用构建的HTTP请求进行设置,因此在手动构建请求或使用批量请求时非常容易使用,但是在使用核心SDK时我似乎找不到最容易注入的地方例如,如果我想为:

设置退避策略
drive.files().get(id).execute();

我做不了类似的事情:

drive.files().get(id)
     .setBackOffPolicy(new ExponentialBackOffPolicy())
     .execute();

我需要这样做:

drive.files().get(id)
     .buildHttpRequest()
     .setBackOffPolicy(new ExponentialBackOffPolicy())
     .execute();

但是,如果我这样做,那么我还需要重现Drive.Files.Get的execute方法的解析逻辑,并将结果转换为File对象,这显然不是一种理想的方法。有没有更简单的方法“一般”将此添加到请求中,或者可能是为所有请求设置默认退避策略的方法?

如果没有,或许可以将其引入未来版本的Drive SDK中?

谢谢, 大卫

3 个答案:

答案 0 :(得分:2)

Google Drive SDK文档包含一个示例,说明如何使用Drive API正确实现指数退避:

https://developers.google.com/drive/handle-errors

答案 1 :(得分:2)

这里是用于指数退避的代码:

boolean thisIsARetry = false;
boolean keepRetrying = true;
int delayTime = 2;
int maxDelayTime = 4;

while(keepRetrying && delayTime <= maxDelayTime) {
    if(thisIsARetry) {
        //sleep for delayTime seconds
        try {
            Thread.sleep(1000 * delayTime);
            delayTime *= 2;
        } catch (Exception e) {
            //print exception
            delayTime *= 2;
            continue;
        }
    } else {
        thisIsARetry = true;
    }

    //the actual network request or some other operation here
    if(ACTUAL_OPERATION_SUCCESS) {
        keepRetrying = false;
    }
}

答案 2 :(得分:0)

AFAIK Google制作的Exponential Backoff仅在下载或上传驱动Java API中的内容时使用。您需要自己的实现来处理其他请求。

我为任何请求实现它所做的就是在请求时包装一个Callable,然后让包装类执行异常处理并重复请求。