初窥Nodejs

1、Node.js 到底是什么?

  1. Node .js是一个服务器端 JavaScript 解释器;
  2. 是一个构建在Chrome JavaScript运行环境的平台,这是很重要的一点,node.js并非一门语言,而是一个平台;
  3. 致力于使构建速度快、稳定的网络程序更简单;
  4. 具备事件驱动和非阻塞I/O的特点,使之轻量级而且高效率;
  5. 很是适合在分布式设备运行数据密集型实时应用程序。

 

  既然想了解Node.js,那么就用它向世界打个招呼吧!node

  1.在nodejs文件加下面建立一个js文件,例如:hello.jsweb

  2.hello.js文件里的内容以下:浏览器

var http=require('http');//引入http module
http.createServer(function(request,response){//建立一个web server
  //回调函数,这样建立server方法就不会阻塞了
  response.writeHead(200,{'contentType':'text/plain'});
  response.end('Hello World!\n');
}).listen(8124);
console.log('Server running at http://127.0.0.1:8124/');

  3.调出cmd.exe,使用  cd \.....\nodejs   到达nodejs文件目录,再输入 node hello.js 运行服务器

  4.打开浏览器,在地址栏输入你设置的端口号  http://127.0.0.1:8124/,刷新,显示“Hello World!”网络

 

2、Node.js的优势

  nodejs做为一个新兴的后台语言,有不少吸引人的地方:
  RESTful API
  单线程
  Node.js能够在不新增额外线程的状况下,依然能够对任务进行并行处理 —— Node.js是单线程的。它经过事件轮询(event loop)来实现并行操做,对此,咱们应该要充分利用这一点 —— 尽量的避免阻塞操做,取而代之,多使用非阻塞操做。
  非阻塞IO
  V8虚拟机
  事件驱动

3、Node 旨在解决什么问题?

  Node 公开宣称的目标是 “旨在提供一种简单的构建可伸缩网络程序的方法”。当前的服务器程序有什么问题?咱们来作个数学题。在 Java™ 和 PHP 这类语言中,每一个链接都会生成一个新线程,每一个新线程可能须要 2 MB 的配套内存。在一个拥有 8 GB RAM 的系统上,理论上最大的并发链接数量是 4,000 个用户。随着您的客户群的增加,若是但愿您的 Web 应用程序支持更多用户,那么,您必须添加更多服务器。固然,这会增长服务器成本、流量成本和人工成本等成本。除这些成本上升外,还有一个潜在技术问题,即用户可能针对每一个请求使用不一样的服务器,所以,任何共享资源都必须在全部服务器之间共享。鉴于上述全部缘由,整个 Web 应用程序架构(包括流量、处理器速度和内存速度)中的瓶颈是:服务器可以处理的并发链接的最大数量。架构

  Node 解决这个问题的方法是:更改链接到服务器的方式。每一个链接发射一个在 Node 引擎的进程中运行的事件,而不是为每一个链接生成一个新的 OS 线程(并为其分配一些配套内存)。Node 声称它毫不会死锁,由于它根本不容许使用锁,它不会直接阻塞 I/O 调用。Node 还宣称,运行它的服务器能支持数万个并发链接。并发

  如今您有了一个能处理数万个并发链接的程序,那么您能经过 Node 实际构建什么呢?若是您有一个 Web 应用程序须要处理这么多链接,那将是一件很 “恐怖” 的事!那是一种 “若是您有这个问题,那么它根本不是问题” 的问题。在回答上面的问题以前,咱们先看看 Node 的工做原理以及它的设计运行方式。框架

 

4、Node.js的应用方向

  在几年的时间里,Node.JS逐渐发展成一个成熟的开发平台,吸引了许多开发者。有许多大型高流量网站都采用Node.JS进行开发,此外,开发人员还可使用它来开发一些快速移动 Web框架。
  除了Web应用外,NodeJS也被应用在许多方面,本文盘点了NodeJS在其它方面所开发的十大使人神奇的项目,这些项目涉及到应用程序监控、媒体流、远程控制、桌面和移动应用等等。
相关文章
相关标签/搜索