全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

解析NodeJS异步I/O的实现

在现在的项目开发中,任何一个大型项目绝对不是简简单单的采用一个种语言和一种框架,因为每种语言和框架各有优势,与其死守一个,不与取各家之所长,依次得到一个高性能、搞扩展的产品。

对于一个.NET开发者,尤其是主要从事Web开发的.NET程序员,个人觉得有必要学习一门性能优越的Web平台开发语言。一个开发者不能简简单单的只学习一门语言,思维应该开阔,从各个方面去看待同样的一个问题,这样或许会得到另一番效果和见解,个人认为应该学习一下其他的语言,这样有利于我们对比语言的优势和缺点,例如java、nodejs、python等等。对于Nodejs这个JavaScript平台,个人觉得.NET程序员有必要学习一下,因为学习NodeJS有助于我们构建一个高性能的Web平台。

NodeJS具有事件驱动、非阻塞I/O等特点,可以很好的处理I/O操作。Node面向网络且擅长并行I/O,能够有效地组织起更多的硬件资源。

这篇博客就来简单的介绍一下NodeJS的异步I/O特点。

一.NodeJS概述:

要学习一个语言或者平台,我们首先应该知道其定义,依据定义来扩展我们的学习思路。Node的定义:”一个大奖在Chrome JavaScript运行时上的平台,用于构建高速、可伸缩的网络程序。NodeJS作为一个异步事件驱动的JavaScript运行时,旨在构建可扩展的网络应用程序。“有关nodejs的背景介绍和安装方法,这里就没有必要介绍了,因为对于nodejs的安装是比较简单,所以在这里赘述就有些显得浪费时间。

学习完Node的定义特点,可能很多人都会好奇这个平台的适用场景是什么,以便在实际的项目开发中应用,不然学习这个就没有意义。主要的应用场景:前后端编程语言环境统一;高性能I/O用于实时应用;并行I/O使得使用者可以更高效地利用分布式环境;并行I/O有效利用稳定接口提升Web渲染能力;云平台的支持;游戏开发(这可能是很多开发者在意的,毕竟现在的游戏开发火热程度已经到了无以附加的地步);工具类应用,与较多的工具方法,使得开发效率大大的提升。

NodeJS异步I/O模型的基本要素:事件循环、观察者、请求对象、I/O线程池这四个共同构成。接下来我们具体了解一下这些知识。

二.NodeJS异步I/O解析:

对于Nginx服务器,很多人都是比较的熟悉,Nginx采用纯C编写而成,用于做Web服务器,在反向代理和负载均衡等服务方面有很好的优势。Node与Nginx服务器有着相似的地方,都是采用事件驱动。

浏览器中JavaScript在单线程上执行,而且还与UI渲染共用一个线程,JavaScript在执行的时候UI渲染和响应应是出于停滞状态。(如果脚本执行的时间超过100毫秒,用户就会感到页面卡顿)。遇到这些情况,我们就会想到异步的方式消除这些等待的问题,对于异步和同步的概念就不做介绍了。

=接下来我们具体的来了解一下NodeJS的事件驱动和非阻塞I/O这些特点,了解这些对于我们更好的学习NodeJS开发和构建高性能的Web平台有更加深远的意义。

1.I/O操作概述:

I/O操作对于任何一个开发者来说都不会陌生,现在我们就简单的谈一下NodeJS的I.O操作。I/O操作分为:单线程串行依次执行;多线程并行执行。这两种方式各有优势和缺点,多线程的代价在于创建线程和执行期线程上下文切换的开销较大,并且多线程面临锁、状态同步的问题。单线程安装顺序执行,在执行中任何一个稍慢都会导致后续执行代码阻塞。对于任务的串行执行(概念上类似于同步执行)和任务的并行执行的描述有如下图:

                       

在NodeJS中利用单线程,远离死锁、状态同步问题,利用异步I/O,让单线程远离阻塞,以便更好的使用CPU。异步I/O是期望I/O的调用不再阻塞后续运算,将原有等待I/O完成这段时间分配给其他需要的业务去执行。   

很多时候一些开发者对异步/同步和阻塞/非阻塞的概念有些分不清,这两者没有什么关联。阻塞I/O是调用之后一定要等到系统内核层面完成所有操作后,调用才结束。非阻塞I/O是在调用后立即返回。关于阻塞I/O和非阻塞I/O有如下图:

 

2.NodeJS异步I/O解析:

事件循环:在进程启动时,Node会创建一个类似于while(true)的循环,每执行一次循环体的过程称为Tick,每个Tick的过程就是查看是否有时间待处理。

观察者:每个时间循环中有一个或多个观察者,判断是否有事件要处理的过程就是向这些观察者询问是否又要处理的事件。

请求对象:从JavaScript发起调用到内核执行完I/O操作的过渡过程中,存在一种中间产物,就是请求对象。

I/O线程池:组装好请求、送入I/O线程池等待执行,完成第一步I/O操作,进入第二部分回调通知。(在Windows中,线程池中的I/O操作调用完毕之后,会将获取的结果存在req->result属性上,然后调用PostQueuedCompletionStatus()通知IOCP,告知当前对象操作已经完成。)

异步I/O有如下图:

三.NodeJS异步编程实例:

前面介绍了异步I/O的相关概念,这里提供一个异步I/O操作的实例:

var config = require('./config.json');
var fs = require("fs");
var http = require('http');
var url_module = require("url");

http.createServer(function (request, response) {
  var key = url_module.parse(request.url).query.replace('key=', '');
  switch (request.method) {
    case 'GET': // Asynchronous Response Generation
      fs.readFile(config.dataPath + key, 'utf8', function(err, value) {
        if (err) {
          // Return File Not Found if file hasn't yet been created
          response.writeHead(404, {'Content-Type': 'text/plain'});
          response.end("The file (" + config.dataPath + key + ") does not yet exist.");
        } else {
          // If the file exists, read it and return the sorted contents
          var sorted = value.split(config.sortSplitString).sort().join('');
          response.writeHead(200, {'Content-Type': 'text/plain'});
          response.end(sorted);
        }
      });
      break;
    case 'POST': // Synchronously append POSTed data to a file
      var postData = '';
      request
        .on('data', function (data) {
          postData += data;
        })
        .on('end', function () {
          fs.appendFile(config.dataPath + key, postData, function(err) {
            if (err) {
              // Return error if unable to create/append to the file
              response.writeHead(400, {'Content-Type': 'text/plain'});
              response.end('Error: Unable to write file: ' + err);
            } else {
              // Write or append posted data to a file, return "success" response
              response.writeHead(200, {'Content-Type': 'text/plain'});
              response.end('success');
            }
          });
        });
      break;
    default:
      response.writeHead(400, {'Content-Type': 'text/plain'});
      response.end("Error: Bad HTTP method: " + request.method);
  }
}).listen(config.serverPort);

console.log('synchronous server is running: ', config.serverPort);

四.总结:

这篇博文是个人初次尝试NodeJS的一个小总结,如有写的不好还望大家多多的包含和指正。对于程序员来说,需要做的就是一直不停的学习,无论是否是自己主要从事的语言,对于学习多种语言,可以更加有助我们了解编程,对于一个开发者来说,最终的就是思想,因为语言的特性和框架的应用,一个熟练的编程者学习起来并不是难事,难就难在我们对于语言和框架的设计理念的理解。


# nodejs异步io的实现  # node  # 异步io  # 异步网络io  # Nodejs异步流程框架async的方法  # Nodejs让异步变成同步的方法  # Nodejs异步回调之异常处理实例分析  # nodejs async异步常用函数总结(推荐)  # NodeJs通过async/await处理异步的方法  # 详解nodejs异步I/O和事件循环  # async/await与promise(nodejs中的异步操作问题)  # 深入浅析NodeJs并发异步的回调处理  # 详解nodejs中的异步迭代器  # 单线程  # 高性能  # 有必要  # 任何一个  # 都是  # 就会  # 很好  # 多线程  # 很多人  # 就没  # 死锁  # 各有  # 这篇  # 一门  # 类似于  # 游戏开发  # 是在  # 在这里  # 尤其是  # 多个 


相关文章: 音乐网站服务器如何优化API响应速度?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  小型网站建站如何选择虚拟主机?  制作网站怎么制作,*游戏网站怎么搭建?  C#怎么使用委托和事件 C# delegate与event编程方法  外贸公司网站制作哪家好,maersk船公司官网?  定制建站是什么?如何实现个性化需求?  ,在苏州找工作,上哪个网站比较好?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  如何用PHP工具快速搭建高效网站?  如何在Ubuntu系统下快速搭建WordPress个人网站?  如何快速搭建高效香港服务器网站?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  C++中引用和指针有什么区别?(代码说明)  制作销售网站教学视频,销售网站有哪些?  c# await 一个已经完成的Task会发生什么  如何实现建站之星域名转发设置?  如何选择CMS系统实现快速建站与SEO优化?  建站主机与虚拟主机有何区别?如何选择最优方案?  智能起名网站制作软件有哪些,制作logo的软件?  中山网站推广排名,中山信息港登录入口?  想学网站制作怎么学,建立一个网站要花费多少?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  Android使用GridView实现日历的简单功能  网站好制作吗知乎,网站开发好学吗?有什么技巧?  如何在局域网内绑定自建网站域名?  高端网站建设与定制开发一站式解决方案 中企动力  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  如何高效完成自助建站业务培训?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何快速搭建二级域名独立网站?  网站代码制作软件有哪些,如何生成自己网站的代码?  广州营销型建站服务商推荐:技术优势与SEO优化解析  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  建站之星导航配置指南:自助建站与SEO优化全解析  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  建站主机类型有哪些?如何正确选型  如何快速上传自定义模板至建站之星?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  网页设计与网站制作内容,怎样注册网站?  建站之星与建站宝盒如何选择最佳方案?  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  Swift中循环语句中的转移语句 break 和 continue  MySQL查询结果复制到新表的方法(更新、插入)  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。