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可以与浏览器客户端建立数千个开放连接.这并不意味着它在每一个上都是阻塞的.它只是意味着它处于空闲状态,直到它有一个要处理的回调或一个新的处理请求.
| 归档时间: |
|
| 查看次数: |
2618 次 |
| 最近记录: |