我正在尝试创建一个并行运行的服务器。我有两个主要的担忧:NodeJS导出阻止代码
- 某些方面阻止和停止正在处理
- 请求弄混和错误的反应去错了客户的请求。
这里是我的代码:
服务器文件:
var http = require('http');
var controller = require('controller.js');
http.createServer(function (request, response) {
controller.handle(request, response);
}).listen(8080, '0.0.0.0');
控制器文件
var resp = require('./resp.js');
var sqltest = require('/sql/sqltest.js');
exports.handle = function(request, response) {
request.on('data', function(chunk) {
var json = JSON.parse(chunk);
var type = parseInt(json["requestType"]);
switch(type) {
case 0:
sqltest.try(json, function(res){
resp.send(response, res);
});
break;
}
});
}
SQL测试文件
var mysql = require('mysql');
exports.try = function(json, callback, res) {
-- doo database stuff --
callback(res);
});
}
响应文件
exports.send = function(response, res){
response.writeHead(200, ......);
response.end(res);
}
基本上,这个服务器将非常大,我不能有行代码成千上万都坐在一个文件。通过分解,我会以任何方式损害性能,这是否会导致任何阻止代码,服务器是否会跟踪正确的客户端以响应?
我还是非常新的节点和JavaScript的一般,所以也许我很想理解基本概念如何工作。任何建议或改进将是一个很大的帮助!
这些都不是问题。 – SLaks