我有一个很好的老式 LAMP webapp。一周前,我需要为其添加一个推送通知机制。
因此,我所做的是在服务器上添加 node.js+socket.io 并使用 node.js 每 10 秒轮询 MySQL 数据库以检查是否有新项目:如果有,我会将它们发送到客户端( s) 使用 socket.io。
我对结果非常满意,即使这不是一个适当的实时通知(因为最多有 10 秒的延迟)。
现在,我即将构建一个新的 web 应用程序,它也需要推送通知。我想知道是采用与第一种方法相同的方法(我相信它更稳定和成熟)还是完全采用 Node.js,而不使用 PHP 和 Apache。至于数据库,我已经决定去MongoDB了。
最后,我的问题是:如果我选择 Node.js+Socket.io+MongoDB,我会得到一个真正 接近实时的webapp 吗?我的意思是,一旦将新记录插入 MongoDB,是否会触发某种事件,我可以通过 node.js 捕获,对其进行检查,如果相关,将通知发送给客户端?还是会像我的第一个 LAMP webapp 一样,在 db 服务器端和延迟上进行某种轮询?
一个相关的问题:你能在 MySQL 上构建一个实时 webapp,而不像我第一个应用程序那样做任何轮询吗?还是您需要 MongoDB(或 Redis)?
我希望这个问题不会太傻 - 抱歉,我只是从 Node.js 和 co 开始。
谢谢。