java - 在 AsyncHttprespons 中使用退避来避免“请求过多”错误
问题描述
我有一个从 Google Books API 读取一些数据的应用程序。
我AsyncHttpRequest
用来获取数据。
我开始收到以下错误:
2021-04-22 20:38:18.083 24736-24736/com.xx.yy V/AsyncHttpRH: Progress 538 from 1 (53800%)
2021-04-22 20:38:18.083 24736-24736/com.xx.yy I/chatty: uid=10089(com.xx.yy) identical 1 line
2021-04-22 20:38:18.086 24736-24736/com.xx.yy V/AsyncHttpRH: Progress 538 from 1 (53800%)
2021-04-22 20:38:18.088 24736-24736/com.xx.yy W/JsonHttpRH: onFailure(int, Header[], Throwable, JSONObject) was not overriden, but callback was received
cz.msebera.android.httpclient.client.HttpResponseException: Too Many Requests
at com.loopj.android.http.AsyncHttpResponseHandler.sendResponseMessage(AsyncHttpResponseHandler.java:446)
at com.loopj.android.http.AsyncHttpRequest.makeRequest(AsyncHttpRequest.java:160)
at com.loopj.android.http.AsyncHttpRequest.makeRequestWithRetries(AsyncHttpRequest.java:177)
at com.loopj.android.http.AsyncHttpRequest.run(AsyncHttpRequest.java:106)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:458)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:764)
2021-04-22 20:38:18.101 24736-24736/com.xx.yy I/chatty: uid=10089(com.xx.yy) identical 5 lines
2021-04-22 20:38:18.101 24736-24736/com.xx.yy W/JsonHttpRH: onFailure(int, Header[], Throwable, JSONObject) was not overriden, but callback was received
cz.msebera.android.httpclient.client.HttpResponseException: Too Many Requests
at com.loopj.android.http.AsyncHttpResponseHandler.sendResponseMessage(AsyncHttpResponseHandler.java:446)
at com.loopj.android.http.AsyncHttpRequest.makeRequest(AsyncHttpRequest.java:160)
at com.loopj.android.http.AsyncHttpRequest.makeRequestWithRetries(AsyncHttpRequest.java:177)
at com.loopj.android.http.AsyncHttpRequest.run(AsyncHttpRequest.java:106)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:458)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:764)
2021-04-22 20:38:18.135 24736-24736/com.xx.yy V/AsyncHttpRH: Progress 538 from 1 (53800%)
2021-04-22 20:38:18.155 24736-24736/com.xx.yy W/JsonHttpRH: onFailure(int, Header[], Throwable, JSONObject) was not overriden, but callback was received
cz.msebera.android.httpclient.client.HttpResponseException: Too Many Requests
at com.loopj.android.http.AsyncHttpResponseHandler.sendResponseMessage(AsyncHttpResponseHandler.java:446)
at com.loopj.android.http.AsyncHttpRequest.makeRequest(AsyncHttpRequest.java:160)
at com.loopj.android.http.AsyncHttpRequest.makeRequestWithRetries(AsyncHttpRequest.java:177)
at com.loopj.android.http.AsyncHttpRequest.run(AsyncHttpRequest.java:106)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:458)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:764)
我不确定是什么原因导致我读到使用 ExponentialBackOff 可能会有所帮助。
我的 AsyncHttpClient 正在使用 loopj 库,它具有:
BackoffManager b = new BackoffManager() {
@Override
public void backOff(HttpRoute route) {
}
@Override
public void probe(HttpRoute route) {
}
}
但我不知道如何在我的课堂上使用它:
public void getBooks(final String query, JsonHttpResponseHandler handler) {
try {
client.get( API_BASE_URL + URLEncoder.encode( query, "utf-8" ), handler );
} catch (UnsupportedEncodingException ignored) {
}
}
关于如何在我的案例中实施此策略的任何建议?
谢谢
解决方案
推荐阅读
- javascript - 如何使用 Viewheight 防止 slick.js 滑块下的空白
- javascript - 如何使月份值成为两位数?
- php - 我的多对多关系未返回所需的用户角色
- php - 无法在 PHP PDO 中使用正确的密码登录
- sql-server - 有效日期历史表的键和索引设计
- java - Collectors.groupingBy 用于可选字段的内部字段
- database - 如果表具有相同的列,最好的方法数据库设计?
- windows - 需要 Nginx access_log 大小限制
- python - 仅当列包含特定值时才使用另一个数据框更新数据框
- javascript - 如何使用 cordova 插件和 java 脚本连接到 Azure IoT 中心?