gpt4 book ai didi

node.js - Node.js+Socket.io+MongoDB webapps 是如何真正异步的?

转载 作者:IT老高 更新时间:2023-10-28 22:05:35 25 4
gpt4 key购买 nike

我有一个很好的老式 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,我会得到一个真正 near-real-time网络应用程序?我的意思是,一旦将新记录插入 MongoDB,是否会触发某种事件,我可以通过 node.js 捕获,对其进行检查,如果相关,将通知发送给客户端?还是会像我的第一个 LAMP webapp 那样在 db 服务器端和延迟上进行某种轮询?

一个相关的问题:你能在 MySQL 上构建一个实时 web 应用程序,而不像我第一个应用程序那样进行任何轮询。还是需要 MongoDB(或 Redis)?

我希望这个问题不是太傻 - 抱歉,我只是从 Node.js 和 co 开始。

谢谢。

最佳答案

我了解您的问题,因为我也从 php/apache/mysql 切换到 node.js

  • 一般来说node.js是稳定的,模块和你的脚本是出错的主要原因

  • 实时与数据库无关,都是关于客户端和服务器的,您可以在请求中查询任意数量的数据并将其推送到其他客户端。

  • 选择 node.js 是非常明智的,但是实现起来比较困难。

  • 当您向数据库插入新记录时,事件就是请求本身,您将与数据库查询一起进行推送事件,如下所示:

    // Please note this is not real code, just an example of the idea
    app.get('/query', function(request, response){
    // Query your database
    db.query('SELECT * FROM users', function(rows){

    // Push notification to dan
    socket.emit('database_query_executed', 'to_dan', rows);

    // End request
    response.end('success');

    })
    })
  • 当然你可以使用MySQL!你想要的任何数据库,正如我所说的,实时与数据库无关,因为数据库处于进程的中间,它是完全可选的。

  • 如果您想将 node.js 用于 推送通知php/apache 用于 mysql 那么你需要为每个服务器创建 2 个请求,例如:

    // this is javascript
    ajax('http://node.yoursite.com/push', node_options)
    ajax('http://php.yoursite.com/mysql_query', php_options)

    或者如果你只想要一个请求,或者你想使用一个表单,你可以调用你的 php 并且在 php 中你可以创建一个 http 或对 node.js 的网络请求 来自 php,类似于:

    // this is php
    new HttpRequest('http://node.youtsite.com/push', HttpRequest::METH_GET);

关于node.js - Node.js+Socket.io+MongoDB webapps 是如何真正异步的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12978168/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com