nodejs入门学习笔记二——解决阻塞问题
2017-10-24 18:07
495 查看
在最开始,我们要弄清楚node会什么会存在阻塞?
node是这么标榜自己的:“在node中除了代码,所有一切都是并行执行的!”
意思是,Node.js可以在不新增额外线程的情况下,依然可以对任务进行并行处理 —— Node.js是单线程的。
也就是说,我们启动的web服务器,监听8888端口的start方法,是单线程的。
如果某一个请求耗时,那么后面的请求要等上一个请求完成之后才执行,这显然是不合理的!
如requestHandlers中start handler:
我们可以使用child_process模块来实现非阻塞操作,其实就是一个异步操作,强调一点,耗时操作通常都需要通过异步操作来处理。
一种错误的示范:
错误原因,exec异步操作后面的不能再跟同步代码,一个简单的例子,juqery ajax请求成功后的后续操作应该在success中处理,而不应该再ajax整个代码块后面处理。
既然后续操作都要在异步回调函数中实现,所以response的处理就要移步至handler中实现。
server.js
router.js
requestHandler.js
node是这么标榜自己的:“在node中除了代码,所有一切都是并行执行的!”
意思是,Node.js可以在不新增额外线程的情况下,依然可以对任务进行并行处理 —— Node.js是单线程的。
也就是说,我们启动的web服务器,监听8888端口的start方法,是单线程的。
如果某一个请求耗时,那么后面的请求要等上一个请求完成之后才执行,这显然是不合理的!
如requestHandlers中start handler:
function start() { console.log("Request handler 'start' was called."); function sleep(milliSeconds) { var startTime = new Date().getTime(); while (new Date().getTime() < startTime + milliSeconds); } sleep(10000); return "Hello Start"; }
我们可以使用child_process模块来实现非阻塞操作,其实就是一个异步操作,强调一点,耗时操作通常都需要通过异步操作来处理。
一种错误的示范:
var exec = require("child_process").exec; function start() { console.log("Request handler 'start' was called."); var content = "empty"; exec("ls -lah", function (error, stdout, stderr) { content = stdout; }); return content; } function upload() { console.log("Request handler 'upload' was called."); return "Hello Upload"; } exports.start = start; exports.upload = upload;
错误原因,exec异步操作后面的不能再跟同步代码,一个简单的例子,juqery ajax请求成功后的后续操作应该在success中处理,而不应该再ajax整个代码块后面处理。
既然后续操作都要在异步回调函数中实现,所以response的处理就要移步至handler中实现。
server.js
var http = require("http"); var url = require("url"); function start(route, handle) { function onRequest(request, response) { var pathname = url.parse(request.url).pathname; console.log("Request for " + pathname + " received."); route(handle, pathname, response); } http.createServer(onRequest).listen(8888); console.log("Server has started."); } exports.start = start;
router.js
function route(handle, pathname, response) { console.log("About to route a request for " + pathname); if (typeof handle[pathname] === 'function') { handle[pathname](response); } else { console.log("No request handler found for " + pathname); response.writeHead(404, {"Content-Type": "text/plain"}); response.write("404 Not found"); response.end(); } } exports.route = route;
requestHandler.js
var exec = require("child_process").exec; function start(response) { console.log("Request handler 'start' was called."); exec("find /", { timeout: 10000, maxBuffer: 20000*1024 }, function (error, stdout, stderr) { response.writeHead(200, {"Content-Type": "text/plain"}); response.write(stdout); response.end(); }); } function upload(response) { console.log("Request handler 'upload' was called."); response.writeHead(200, {"Content-Type": "text/plain"}); response.write("Hello Upload"); response.end(); } exports.start = start; exports.upload = upload;
相关文章推荐
- Netty5入门学习笔记002-TCP粘包/拆包问题的解决之道(上)
- Netty5入门学习笔记002-TCP粘包/拆包问题的解决之道(上)
- Netty5入门学习笔记002-TCP粘包/拆包问题的解决之道(上)
- ajax学习笔记---解决浏览器缓存和中文乱码问题
- SilverLight学习笔记--如何解决Button不响应MouseLeftButtonDown与MouseLeftButtonUp事件的问题
- 学习笔记---递归的代码,解决经典的汉诺塔问题
- [学习笔记][ASP.NET2.0][点击asp:Button出现两次提交数据的问题][解决:去掉OnClick或者OnCommand属性]
- ASP.NET学习笔记----解决页面中部分验证的问题:validationgroup,爽(20080326)
- 我的嵌入式学习笔记(2)--scanf使用常见问题及解决方法
- spring学习笔记①spring出现为了解决什么问题?
- 【记录】JS正则表达式(学习笔记2)现学现卖还帮美女解决了个问题。
- Android开发学习笔记(11):Android问题解决对策集(更新中...)
- CEGUI学习笔记 -- 使用CEGUI解决具体问题
- ESXi(ESXi 4.1)相关问题解决方法和操作学习笔记
- CEGUI学习笔记六-- 使用CEGUI解决具体问题
- linux 学习笔记 gdb问题解决
- 关于asp.net 2.0 入门学习之“GlobalResources与Callback问题”的笔记
- ArcGIS API for Silverlight 入门学习笔记(一)hello world 补充问题
- ASP.NET学习笔记[1] - iis不能使用的问题解决
- 我的嵌入式学习笔记(2)--scanf使用常见问题及解决方法