更改排球超时时间


190

我使用新的Android Volley框架向服务器发出请求。但是它确实会响应,但是在获得响应之前会超时。

我尝试添加以下代码:

HttpConnectionParams.setConnectionTimeout(httpParams, 5000);
HttpConnectionParams.setSoTimeout(httpParams, timeoutMs);

HttpClientStack将Volley框架的in 设置为另一个整数(50000),但仍在50秒之前超时。

有没有办法将超时更改为长值?



21
@AdamStelmaszczyk-这不会重复,因为它涉及Volley框架中的特定细节。所引用的SO问题是否与HttpClient类的使用有关。
Michael Banzon 2013年

Answers:


357

请参阅Request.setRetryPolicy()和的构造函数DefaultRetryPolicy,例如

JsonObjectRequest myRequest = new JsonObjectRequest(Method.GET,
        url, null,
        new Response.Listener<JSONObject>() {

            @Override
            public void onResponse(JSONObject response) {
                Log.d(TAG, response.toString());
            }
        }, new Response.ErrorListener() {

            @Override
            public void onErrorResponse(VolleyError error) {
                Log.d(TAG, "Error: " + error.getMessage());
            }
});

myRequest.setRetryPolicy(new DefaultRetryPolicy(
        MY_SOCKET_TIMEOUT_MS, 
        DefaultRetryPolicy.DEFAULT_MAX_RETRIES, 
        DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));

您还知道如何设置请求的优先级吗?
Markus

2
@Markus覆盖Request.getPriority()以返回除“ normal”以外的内容。ImageRequest执行此操作。注意:您应该在一个单独的SO问题中提出这个问题。
larham1

1
这正是我要防止Volley放弃耗时15秒的请求的目的。-谢谢!
老虎机

我刚刚为POST请求添加了此功能,以禁用超时重试。Google开发人员决定对POST请求设置重试政策,这是令人难以置信的错误。解决了我的问题。谢谢。
Proverbio

1
@ Roon13请参阅刚刚添加的示例请求构造函数。
larham1 2015年

226

要处理Android Volley Timeout,您需要使用 RetryPolicy

重试政策

  • Volley提供了一种简单的方法来实现您的请求的RetryPolicy。
  • Volley将所有请求的默认Socket&ConnectionTImeout设置为5秒。

RetryPolicy 是一个接口,您需要在其中实现超时时如何重试特定请求的逻辑。

它处理了这三个参数

  • 超时-指定每次重试尝试的套接字超时(以毫秒为单位)。
  • 重试次数-尝试重试的次数。
  • Back Off Multiplier-一个乘数,用于确定每次重试尝试设置给套接字的指数时间。

对于前。如果使用这些值创建了RetryPolicy

超时-3000毫秒,重试次数-2,退避乘数-2.0

重试尝试1:

  • 时间=时间+(时间*后退乘数);
  • 时间= 3000 + 6000 = 9000ms
  • 套接字超时=时间;
  • Socket超时为9秒时分派的请求

重试尝试2:

  • 时间=时间+(时间*后退乘数);
  • 时间= 9000 + 18000 = 27000ms
  • 套接字超时=时间;
  • 套接字超时为27秒时调度的请求

因此,在“ 重试尝试2 ”结束时,如果仍然发生套接字超时,Volley会TimeoutError在您的UI错误响应处理程序中抛出a 。

//Set a retry policy in case of SocketTimeout & ConnectionTimeout Exceptions. 
//Volley does retry for you if you have specified the policy.
jsonObjRequest.setRetryPolicy(new DefaultRetryPolicy(5000, 
                DefaultRetryPolicy.DEFAULT_MAX_RETRIES, 
                DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));

感谢您提供有关RetryPolicy实现实际作用的详细答案。
dbm

5
@Yakiv Mospan是个不错的答案,但是在您的示例中,第一次尝试的时间是0 +(3000 * 2),而不是3000 +(3000 * 2)。和第二个6000 +(3000 * 2)。
2015年

13KZ,我认为您在时间计算上还是错的,请参阅我的编辑并针对凌空声源进行验证
Protongun

1
:使用此人只是一个提醒总是使用new DefaultRetryPolicy(,并确保永远不会重用一个RetryPolicy对象,该对象是通过所有的请求过程中引用,然后重试增量在同一个对象的超时值增加,从而使你的未来的请求超时无限增长
IG Pascual,

连接握手超时如何?
GMsoF'17年

23

只是为我的方法做出贡献。正如已经回答的,RetryPolicy是要走的路。但是,如果对于所有请求都需要使用不同于默认策略的策略,则可以在基本Request类中进行设置,因此无需为所有请求实例设置策略。

像这样:

public class BaseRequest<T> extends Request<T> {

    public BaseRequest(int method, String url, Response.ErrorListener listener) {
        super(method, url, listener);
        setRetryPolicy(getMyOwnDefaultRetryPolicy());
    }
}

在我的情况下,我有一个从此BaseRequest扩展的GsonRequest,所以我不会冒忘记为特定请求设置策略的风险,如果某些特定请求需要,您仍然可以覆盖它。


1
这应该工作对吗?setRetryPolicy(new DefaultRetryPolicy(1000,DefaultRetryPolicy.DEFAULT_MAX_RETRIES,DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));;
LOG_TAG 2015年

12
/**
 * @param request
 * @param <T>
 */
public <T> void addToRequestQueue(Request<T> request) {

    request.setRetryPolicy(new DefaultRetryPolicy(
            MY_SOCKET_TIMEOUT_MS,
            DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
            DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));

    getRequestQueue().add(request);
}

7
req.setRetryPolicy(new DefaultRetryPolicy(
    MY_SOCKET_TIMEOUT_MS, 
    DefaultRetryPolicy.DEFAULT_MAX_RETRIES, 
    DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));

您可以将其设置MY_SOCKET_TIMEOUT_MS为100。要将其设置为毫秒。DEFAULT_MAX_RETRIES可以为0,默认为1。


4
int MY_SOCKET_TIMEOUT_MS=500;

 stringRequest.setRetryPolicy(new DefaultRetryPolicy(
                MY_SOCKET_TIMEOUT_MS,
                DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
                DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));

3

另一种方法是在自定义JsonObjectRequest中通过以下方式进行:

@Override
public RetryPolicy getRetryPolicy() {
    // here you can write a custom retry policy and return it
    return super.getRetryPolicy();
}

来源:Android Volley示例


2

如果上述所有解决方案都不适合您,请选择其他解决方案

默认情况下,Volley会同时为setConnectionTimeout()和设置timeout setReadTimeout()的值RetryPolicy。就我而言,Volley对大数据块抛出超时异常,请参阅:

com.android.volley.toolbox.HurlStack.openConnection(). 

我的解决方案是创建一个HttpStack使用我自己的setReadTimeout()策略扩展的类。然后在创建时使用它RequestQueue,如下所示:

Volley.newRequestQueue(mContext.getApplicationContext(), new MyHurlStack())

1

我最终在中添加了一个方法setCurrentTimeout(int timeout)RetryPolicy并在中实现了它DefaultRetryPolicy

然后我setCurrentTimeout(int timeout)在Request类中添加了一个,并将其命名为。

这似乎可以完成工作。

抱歉,我很懒惰,对开放源代码表示敬意。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.