设为首页 收藏本站
查看: 1226|回复: 0

[经验分享] 纸上得来终觉浅,绝知此事要躬行。

[复制链接]

尚未签到

发表于 2017-2-25 09:08:07 | 显示全部楼层 |阅读模式
介绍
  在读这篇博客之前,我强列建议先阅读我的前两篇文章:


  • Getting Started With Node.js
  •   Node.js - Modules
      在这篇文章中,我们将学习 Node.js 中的事件循环(event loop)。我们还将了解 Node.js 的代码执行过程。在我第一篇文章中我告诉大家 Node.js 是一个单线程的应用程序。因为 Node.js 运行的是 JavaScript,然而 JavaScript 是不支持多线程的,所以 Node.js 也不支持多线程。但是 Node.js 使用事件和回调(event and callbacks)的概念可以支持并发。这一切归咎都是事件循环(event loop)的功劳。

事件循环(event loop)的工作机制
  在 Getting Started With Node.js 这篇文章中我们已经了解了 Node.js 的架构,其中我们还讨论了 Node.js 的两个主要组件:Google's V8 引擎 和 Libuv。其中事件循环(event loop)是用 C 和 C++ 编写的 Libuv 的一部分。
  
DSC0000.gif
  
上图是 Node.js 的执行过程,让我们来一步一步理解它。


  • 每当请求进入 Node.js 的 API 时将会被添加到事件循环(event loop)的队列,因为 Node.js 不能同时处理多个请求。所以,所有的请求进来后将会被添加到事件队列里面。
  • 现在,你可以在上图中看到一个循环,它总是检查事件或请求是否在事件队列中可用。如果有任何请求可用,那么根据队列的“先进先出”的特性,该请求将会被处理。
  • Node.js 的事件循环(event loop)是单线程执行的非阻塞 I/O 任务。它将请求发送到 C++ 内部线程池(thread pool),里面可以运行大量的线程任务。这个内部 C++ 线程池(thread pool)是 Libev 组件中开发的事件循环(event loop)的一部分,它可以处理多个请求。事件循环一直检查事件队列中是否存在任务,如果有并且阻塞进程存在,将会有线程池来处理。
  • 现在,内部线程池(thread pool)可以处理很多请求,就像对数据库请求,对文件的操作等等。
  • 每当有线程完成任务,将会调用回调函数(callback function),并将响应结果发送回事件循环(event loop)。
  • 事件循环将响应发送回请求客户端完成一次请求处理。
示例
  下面的示例将会展示事件循环(event loop)的工作机制:
var fs = require('fs');  
var i = 1;  
  
fs.watch("file.txt", function (event, filename) {  
  var EventId = "#" + i;  
  var EventName = " Event: " + event;  
  var FileName = " FileName: " + filename;  
  var Time = " Time: " + new Date();  
  var data = EventId.concat(EventName, FileName, Time, "\n");  
  console.log(data);  
  i++;  
  
});  
  
console.log("Now we are watching file.txt\n");  
  在上面的示例中,第一行加载了 fs 模块用于操作文件系统,并且定义了一个变量 i 来做为计数器。然后使用 fs.watch() 方法来监视 file.txt 文件。这个监视方法的回调函数的参数包含了事件(event)和文件名(filename)。所以,每当文件有变化,这个回调函数将会被调用,并将日志打印到控制台上面。我们将上面的代码保存为 app.js。
  
注:我的 file.txt 文件和 app.js 在同一个目录,我的文件结构如下图如示:
  
DSC0001.gif
  
现在,我们运行程序,并修改这个 file.txt 文件。当我们保存后,将会看到下面的输出日志:
  
DSC0002.gif
  
上面的结果显示,当 file.txt 发生任何变化,fs.watch() 的回调函数将会在事件循环(event loop)中被调用,并且事件循环(event loop)将会一直检查文件是否发生了变化。你还可以使用下面的代码将该事件信息记录在一个文件中:
var fs = require('fs');  
fs.writeFile('log.txt', '', function (err) {  
  if (err) throw err;  
  console.log('File Saved Successfully!');  
  
});  
  
var i = 0;  
  
fs.watch("target.txt", function (event, filename) {  
  var EventId = "#" + i;  
  var EventName = " Event: " + event;  
  var FileName = " FileName: " + filename;  
  var Time = " Time: " + new Date();  
  var data = EventId.concat(EventName, FileName, Time,"\n");  
  fs.appendFile('log.txt', data, function (err) {  
  if (err) {  
  console.log(err);  
  }  
  });  
  i++;  
  
});  
  好了,我希望这篇文章对你有帮助。谢谢!
  译:http://www.c-sharpcorner.com/article/node-js-event-loop/

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-346849-1-1.html 上篇帖子: Install elasticsearch-head: – for Elasticsearch 5.x 下篇帖子: 程序猿眼中的高并发
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表