一、Node.js 究竟是什么?
- Node .js是一个服务器端 JavaScript 解释器;
- 是一个构建在Chrome JavaScript运行环境的平台,这是很重要的一点,node.js并不是一门语言,而是一个平台;
- 致力于使构建速度快、稳定的网络程序更简单;
- 具有事件驱动和非阻塞I/O的特色,使之轻量级并且高效率;
- 非常适合在分布式设备运行数据密集型实时应用程序。
既然想了解Node.js,那么就用它向世界打个招呼吧!
1.在nodejs文件加下面创建一个js文件,例如:hello.js
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! '); }).listen(8124); console.log('Server running at http://127.0.0.1:8124/');
3.调出cmd.exe,使用 cd ..... odejs 到达nodejs文件目录,再输入 node hello.js 运行
4.打开浏览器,在地址栏输入你设置的端口号 http://127.0.0.1:8124/,刷新,显示“Hello World!”
二、Node.js的优点
三、Node 旨在解决什么问题?
Node 公开宣称的目标是 “旨在提供一种简单的构建可伸缩网络程序的方法”。当前的服务器程序有什么问题?我们来做个数学题。在 Java™ 和 PHP 这类语言中,每个连接都会生成一个新线程,每个新线程可能需要 2 MB 的配套内存。在一个拥有 8 GB RAM 的系统上,理论上最大的并发连接数量是 4,000 个用户。随着您的客户群的增长,如果希望您的 Web 应用程序支持更多用户,那么,您必须添加更多服务器。当然,这会增加服务器成本、流量成本和人工成本等成本。除这些成本上升外,还有一个潜在技术问题,即用户可能针对每个请求使用不同的服务器,因此,任何共享资源都必须在所有服务器之间共享。鉴于上述所有原因,整个 Web 应用程序架构(包括流量、处理器速度和内存速度)中的瓶颈是:服务器能够处理的并发连接的最大数量。
Node 解决这个问题的方法是:更改连接到服务器的方式。每个连接发射一个在 Node 引擎的进程中运行的事件,而不是为每个连接生成一个新的 OS 线程(并为其分配一些配套内存)。Node 声称它绝不会死锁,因为它根本不允许使用锁,它不会直接阻塞 I/O 调用。Node 还宣称,运行它的服务器能支持数万个并发连接。
现在您有了一个能处理数万个并发连接的程序,那么您能通过 Node 实际构建什么呢?如果您有一个 Web 应用程序需要处理这么多连接,那将是一件很 “恐怖” 的事!那是一种 “如果您有这个问题,那么它根本不是问题” 的问题。在回答上面的问题之前,我们先看看 Node 的工作原理以及它的设计运行方式。