Длинный опрос Android https: невозможно получить ответ, если интервал опроса превышает 70 секунд

Я пытаюсь реализовать долгую службу push-опросов в своем приложении для Android (на основе Microsoft AUTD ActiveSync -> http://technet.microsoft.com/en-us/library/aa997252.aspx).

Серверную часть с сервлетами 3.0 я уже реализовал на Tomcat 7.0. Я протестировал свои AsyncServlets с CURL, все работает нормально.

Вот как я тестировал свой AsyncServlet:

curl "https://webservice.mydomain.net/push?id=1&heartbeat=180000" --insecure --user user:password -D -

Ответ сервера через 3 минуты (интервал пульса)

HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Pragma: No-cache
Cache-Control: no-cache
Expires: Thu, 01 Jan 1970 01:00:00 CET
Content-Type: application/json;charset=ISO-8859-1
Content-Length: 0
Date: Sat, 15 Jan 2011 23:38:57 GMT

В моем приложении для Android я использовал следующий код:

HttpParams httpParams = mDefaultHttpClient.getParams();
HttpConnectionParams.setConnectionTimeout(httpParams, CONNECTION_TIMEOUT);
HttpConnectionParams.setSoTimeout(httpParams, mHeartbeat + TIMEOUT_TOLERANCE);
mDefaultHttpClient.setParams(httpParams);

HttpGet httpGet = new HttpGet(mPushURL);
httpGet.addHeader("Accept", "application/json");

try {
    Log.i(TAG, "Executing GET(PUSH) request " + httpGet.getRequestLine());
    HttpResponse httpResponse = mDefaultHttpClient.execute(httpGet);
    Log.i(TAG, httpResponse.getStatusLine().toString());
    Log.i(TAG, convertInputStream(httpResponse.getEntity().getContent())); //For testing purposes
} catch (ClientProtocolException e) {
    e.printStackTrace();
} catch (IOException e) {
    e.printStackTrace();
}

Я провел несколько тестов. Если я использую 70-секундный интервал сердцебиения, я получаю ответ. Если я использую интервал сердцебиения > 70 секунд, я получаю (после указанного интервала сердцебиения) исключение SocketTimeoutException вместо моего ответа HTTP 200 OK. (Чтобы уточнить: мой набор SocketTimeout (SoTimeout) работает правильно, но, возможно, соединение потеряно, я понятия не имею, почему).

Спасибо за каждый ответ.


person sebyz    schedule 16.01.2011    source источник


Ответы (2)


Используйте URLConnection и установите readTimeOut. Купить трудно сказать. Я думаю, что сетевой уровень Android замораживает открытые соединения. (я работаю над подобным проектом. Не смог найти, почему открытые соединения зависают)

person Enes    schedule 14.07.2011

Попробуйте добавить:

ConnManagerParams.setTimeout(params, CONNECTION_TIMEOUT);
person robsf    schedule 16.03.2011