首页 / PHP / APP做用户排队功能,是拉取还是推送?
APP做用户排队功能,是拉取还是推送?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了APP做用户排队功能,是拉取还是推送?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2420字,纯文字阅读大概需要4分钟。
内容图文
![APP做用户排队功能,是拉取还是推送?](/upload/InfoBanner/zyjiaocheng/239/e572a9a7fe554db493d33eaa301c817b.jpg)
遇到的问题:我目前采用的是APP通过定时轮询请求服务端接口,如果APP突然断网,就会卡住队伍,后面的人排不到前面来。我这边写了一个计划任务在后台清理这些异常的用户,个人感觉不是十分理想,请教各位大牛,如果采取推送的方式是否比客户端轮询更有优势?(排队的人数肯定不会超过1000),如果采用推送是用计划任务还是通过某个用户服务完毕或刚加入队伍的用户进行触发推送,或者说有没有其他的方式?
目前还有一种情况就是如果采用APP轮询请求接口,一旦APP进入后台,也就是按了home键之类的,就不会继续请求我的接口,也会被后台程序认为是异常用户清除掉了。
回复内容:
APP功能概述:用户打开APP有一个领取排队号的功能,领取到号后进入等待,等待的过程会显示你排到第几名,大概等待多久,用户会实时的看到排队的信息变化。有点像去银行排队办业务。
遇到的问题:我目前采用的是APP通过定时轮询请求服务端接口,如果APP突然断网,就会卡住队伍,后面的人排不到前面来。我这边写了一个计划任务在后台清理这些异常的用户,个人感觉不是十分理想,请教各位大牛,如果采取推送的方式是否比客户端轮询更有优势?(排队的人数肯定不会超过1000),如果采用推送是用计划任务还是通过某个用户服务完毕或刚加入队伍的用户进行触发推送,或者说有没有其他的方式?
目前还有一种情况就是如果采用APP轮询请求接口,一旦APP进入后台,也就是按了home键之类的,就不会继续请求我的接口,也会被后台程序认为是异常用户清除掉了。
我个人觉得是这样哈,看你业务需求里客户对即时性要求高不高;如果像滴滴打车那样,要一直看见变化的,可以轮询+推送;如果要求不高,可以只推送。感觉推送比轮询重要哈。
主要是不知道这个用户的排队策略;如果是他一进入后台,就视为自动放弃,那么轮询还可以;否则的话,等排到他了他不知道,你把他清掉了,这属于正确性的问题呀~ 还不是系统设计的问题。
我个人觉得一个常见的排队策略是,客户端发一个请求排到队列后面;轮到一个用户,发个推送给他,要求他确认;如果超时不确认,就轮到下一个人。如果用户需要能实时看见排队情况,就加个轮询定时更新;否则就手动更新或者进入界面的时候更新一下就行了。
不知道你们的业务需求是什么~ 系统设计应该贴合业务需求哈。
对即时性要求较高的话,可以采用轮询+推送的方式,优化轮询的方案可以采用'WebSocket'。
如果上面的方式还不能满足需求,建议采用'Socket'通知客户端刷新。
无论是'WebSocket'还是'Socket',都只完成通知刷新的任务,获取数据的方式还是保持Http方式,这样可以在现有基础上降低开发量。
建议推送,轮询太耗服务器资源!
轮询+推送 吧~
推送估计你是用第三方的吧?所以不能太依赖第三方推送。android那么多机子,推送进程被杀毒软件什么的杀死,就扑街了....
内容总结
以上是互联网集市为您收集整理的APP做用户排队功能,是拉取还是推送?全部内容,希望文章能够帮你解决APP做用户排队功能,是拉取还是推送?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。