nodejs和非阻塞的噩梦

kas*_*par 3 mysql nonblocking node.js

我目前正在使用node.js和MySQL开发API.我是这个非阻塞的新手,我有一个问题.我正在使用节点和MySQL模块.

假设我们有这样的函数:

function doQuery(sql, callback) {
    connect(); //does the Client.connect()
    client.query(sql, function(err, results, fields) {
        if (err) {
            errorLog.trace(err, __filename);
            throw err;
        } else {
            logger.trace('DATABASE ACCESS: {query: ' + sql + '} result: OK', __filename);
        }
        client.end();

        callback(results);
    });
}
Run Code Online (Sandbox Code Playgroud)

一切运行正常,回调处理值的返回,但有些东西困扰我.我的浏览器是什么,直到响应回来,我不知道这是因为在此期间节点实际上是被阻止的.

那么,我怎么知道一个操作是否实际阻塞了我的节点进程?我认为当您将回调传递给函数时,节点会自动处理它并将此回调的执行放在事件循环的队列中.但我真的不确定

这一切对你有意义吗?

Ray*_*nos 15

浏览器等待和node.js阻塞之间存在差异.

浏览器必须等待,因为它无法立即恢复数据.一旦发回响应,浏览器将停止等待.仅仅因为浏览器正在等待并不意味着node.js正在阻塞.它只是意味着连接仍然是开放的

Node.js在等待回调时闲置.它不会阻止.

node.js可以与浏览器客户端建立数千个开放连接.这并不意味着它在每一个上都是阻塞的.它只是意味着它处于空闲状态,直到它有一个要处理的回调或一个新的处理请求.