我偶尔注意到我的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中?
谢谢, 大卫
答案 0 :(得分:2)
Google Drive SDK文档包含一个示例,说明如何使用Drive API正确实现指数退避:
答案 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,然后让包装类执行异常处理并重复请求。