推送使用的是androidpn,当Server晚于Client启动或者Client连接后,Server重启,会出现Client无法再连接的情况。分析是因为Client的连接时,对队列的管理有些问题, private void addTask(Runnable runnable) {
Log.d("addTask(runnable)...");
taskTracker.increase();
synchronized (taskList) {
if (taskList.isEmpty() && !running) {
running = true;
futureTask = taskSubmitter.submit(runnable);
if (futureTask == null) {
taskTracker.decrease();
}
} else {
runTask();
taskList.add(runnable);
}
}
Log.d("addTask(runnable)... done");
} 当连接不上服务器时候抛出异常,导致任务列表一直处于被添加而没有执行,需要在esle里面手动跑起连接线程。 如果当之前pn连接成功,服务器重启,那么需要在服务器断开,捕捉到登录失败异常的时候 } 执行xmppManager.setConnection(null);将判断是否已经连接服务器置空。这样程序就会自动重新去连接服务器,成功建立新的会话。
} catch (XMPPException e) {
xmppManager.setConnection(null);
Log.e("LoginTask.run()... xmpp error");
Log.e("Failed to login to xmpp server. Caused by: " + e.getMessage());
e.printStackTrace();
String INVALID_CREDENTIALS_ERROR_CODE = "401";
String errorMessage = e.getMessage();
if (errorMessage != null && errorMessage.contains(INVALID_CREDENTIALS_ERROR_CODE)) {
xmppManager.reregisterAccount();
return;
}
xmppManager.startReconnectionThread();