> 백엔드 개발 > PHP 튜토리얼 > workerman 怎么实现mysql数据库里面的一个表一旦有新的数据的加入,就把新的数据发送到前端?

workerman 怎么实现mysql数据库里面的一个表一旦有新的数据的加入,就把新的数据发送到前端?

WBOY
풀어 주다: 2016-06-06 20:19:38
원래의
1716명이 탐색했습니다.

我的需求是这样的,使用workerman 来做前后端的长链接,然后mysql的一张表一旦有了新的数据,就把新的数据发送到前端,发送的数据是个数组,我该怎么实现?如果我的描述不够清楚,请再问,本人在线等,谢谢大神帮忙解决了.

回复内容:

我的需求是这样的,使用workerman 来做前后端的长链接,然后mysql的一张表一旦有了新的数据,就把新的数据发送到前端,发送的数据是个数组,我该怎么实现?如果我的描述不够清楚,请再问,本人在线等,谢谢大神帮忙解决了.

http://www.workerman.net/web-sender
可以通过workerman的phpsocket.io推送

http://wenda.workerman.net/?/question/508
可以在Worker中开一个text端口推送

http://workerman.net/gatewaydoc/advanced/push.html
利用workerman的gatewayWorker推送,使用GatewayClient

什么时候触发以及怎么触发需要自己控制

我一般使用redis来解决。

在插入表的地方进行判断,是否需要把数据发送给前端

使用触发器吧,先创建自定义函数,函数会访问你需要回调的程序的端口,然后触发器里面调用该函数----我说的是mysql触发器,mysql diy函数可以直接用c来写,方便又快捷,php装一个多线程模块,监听两个端口,一个用于与前端websocket进行交互,一个用于接收mysql触发器发送过来的数据,可以在数据库中建立一个socketid表用来关联各个线程,其实这种破事用.net会比较好写

可以定时查下数据库,如果有数据,就调workerman的接口发过去

我当年遇到这个需求,需要数据库主动推送数据给应用程序通知,然并未发现啥解决方案,这个要问dba是不是有这种手段,我解决方案当时用的定时任务,轮训的数据库~

另外,数据的录入过程那里能不能给你系统个通知啥的,具体可以聊聊设计

没接触过workerman,代码也写得少,仅仅提供一种思路:

<code>在写入数据 的代码那里加一个 拦截函数,起到通知workerman的作用</code>
로그인 후 복사

这个有个局限性,就是数据库有多个写入口的话,这样就很蛋疼。

尽量不要与mysql结合

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