> 백엔드 개발 > PHP 튜토리얼 > mysql - PHP服务 安卓推送 后台化

mysql - PHP服务 安卓推送 后台化

WBOY
풀어 주다: 2016-06-06 20:39:29
원래의
1102명이 탐색했습니다.

问题是这样的:

<code>一个微博系统,客户端调用PHP服务对某条微博发表评论,插入数据库成功需要推送给微博主人。
但是推送用的第三方API,不能保证很快返回成功与否的信号,这样这个发表评论的服务就一直等待,也不给客户端传成功的信号。
</code>
로그인 후 복사
로그인 후 복사

然后:

等到超过了服务的最大限制运行时间就啥都不返回给客户端,客户端提示服务错误。
等到超过了客户端的最大限制网络连接时间就提示网络错误。

我现在想实现的是,只要插入数据库成功就返回信号,推送的工作单独来做,存在几个问题:
1.如果用cron定时任务+评论是否推送标示,这样每秒就要查一遍数据库看看是否有没有推送的数据,然后推送,这样对数据库压力太大了,浪费系统资源。
2.如果是分布式,是否有更好更正规的方法...我感觉我就是个野战军...

回复内容:

问题是这样的:

<code>一个微博系统,客户端调用PHP服务对某条微博发表评论,插入数据库成功需要推送给微博主人。
但是推送用的第三方API,不能保证很快返回成功与否的信号,这样这个发表评论的服务就一直等待,也不给客户端传成功的信号。
</code>
로그인 후 복사
로그인 후 복사

然后:

等到超过了服务的最大限制运行时间就啥都不返回给客户端,客户端提示服务错误。
等到超过了客户端的最大限制网络连接时间就提示网络错误。

我现在想实现的是,只要插入数据库成功就返回信号,推送的工作单独来做,存在几个问题:
1.如果用cron定时任务+评论是否推送标示,这样每秒就要查一遍数据库看看是否有没有推送的数据,然后推送,这样对数据库压力太大了,浪费系统资源。
2.如果是分布式,是否有更好更正规的方法...我感觉我就是个野战军...

python ssdb 做个推送队列不难

用队列的方式,当有推送的工作时,先把推送工作堆入队列,直接返回成功的信号。让队列后台完成这些耗时的操作,推荐rabbitmq

用队列就好了,直接将同步的耗时操作转成异步的操作,但是异步后就会带来前端延迟的问题。所以整个完整的解决方案应该是,用户发起评论后,将评论请求写任务队列,并返回成功给客户端,但此时由于评论请求并没有真正执行,因此用户想要读此评论消息时,应该从任务队列中读取相关消息,如果没有读到,再去DB中拉取此消息。

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿