java–Android长轮询TCP连接

java–Android长轮询TCP连接,第1张

概述即时通讯试图在不使用外部库或gcm的情况下进行适当的“推送”.首先我尝试使用asmack的xmpp,然后使用paho或ibmmqtt客户端使用mosquitto,使用alarmtimer调试http.最后我以执事和meteord结束但是因为它不是很好(在服务器端–高CPU和内存负载)我试图做一个longpolling连接.我知

即时通讯试图在不使用外部库或gcm的情况下进行适当的“推送”.

首先我尝试使用asmack的xmpp,然后使用paho或ibm mqtt客户端使用mosquitto,使用alarmtimer调试http.

最后我以执事和meteord结束但是因为它不是很好(在服务器端 – 高cpu和内存负载)我试图做一个longpolling连接.

我知道它需要一个心跳,最后我在考虑延迟(300秒心跳应该足够了?)和正确的方法.

从服务器向客户端发送Heartbeat(1字节或其他)(延迟例如300秒)并在客户端300设置套接字超时更好(电池使用等等),还是更好的发送它从客户端到服务器?

目前我正在使用一个服务,它在onCreate中注册一个观察者并在onDestroy中取消注册.

Observer正在观察一个在Thread中建立tcp套接字连接的对象,并在断开连接时重试它(套接字超时).

如果网络连接发生变化,我还会检查广播密码,并在需要时重新连接.

设备进入待机状态时会发生什么?我是否真的需要一个告警管理器或timertask来接收或发送数据包?

设备是否会丢弃它进入待机状态的连接?

目前我尝试从服务器发送到客户端,延迟120秒,即使设备显示仍然可以发送心跳.

但至少看起来电池耗尽不是“可接受的”.

那么……最好的方法是什么?

谢谢你到目前为止.

解决方法:

这样做的最佳解决方案是使用REST和Comet Server或至少NGinx和Push Stream Module和Long Polling.我还创建了一个返回粘性并在启动时创建线程的服务.线程连接.即使在待机和/或深度睡眠中它仍然可以工作.

总结

以上是内存溢出为你收集整理的java – Android长轮询TCP连接全部内容,希望文章能够帮你解决java – Android长轮询TCP连接所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/web/1117051.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-29
下一篇2022-05-29

发表评论

登录后才能评论

评论列表(0条)

    保存