• 让我欲罢不能的node.js


    从我大一接触第一门编程语言C开始,到现在工作三年陆续接触到了C、汇编、C++、C#、Java、JavaScript、PHP,还有一些HTML、CSS神马的,从来没有一门语言让我像对node.js一样的着迷。接触nodejs在我之前博客提到过在搞web socket在选择服务器的时候很多人推荐nodejs版的,无奈当时对nodejs没有任何概念,所以没看懂人家写的代码,但是感觉很熟悉,网上基本是以在服务器端运行的javascript来解释什么是nodejs,这就让我更疑惑了,javascript怎么可能做socket服务器,在用C#写出服务器后回头看了一下node.js,十分钟之后我就被完全吸引住了。

    补记:由于写博客是对nodejs处于了解语法阶段,很多问题没有说清楚,点反对的人不少,关于一些原理性东西可以看看关于node.js的误会

    什么是node.js

    到底什么是node.js呢?看看官网对nodejs的描述:

    Node.js is a platform built on Chrome's JavaScript runtime for easily building fast, scalable network applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient, perfect for data-intensive real-time applications that run across distributed devices.

    我们可以对此总结出几点

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

    服务器端运行的JavaScript?

    Chrome JavaScript runtime也就是我们常说的 Chrome的V8 JavaScript Engine,也就是Goole开发的一个用于Chrome浏览器的底层JavaScript引擎,用于解析JavaScript语句创建其运行环境,保证我们写的语句在浏览器上的表现和我们预期的一致。

    那么为什么说node.js是服务器端运行的JavaScript?好好地nodejs干嘛要和V8扯上关系?除了Google搞的V8解释JavaScript十分的快,十分重要的一个原因是V8 JavaScript 引擎并不仅限于在浏览器中运行,可以嵌入任何应用程序中运行。Node.js 和.net framework类似是一个平台(这里有些搞不明白,望大神们指点一二),但它没有像.net一样创造了一门语言——C#在这个平台上运行,而是很巧妙的借用了web开发人员已经非常熟悉的JavaScript语法,使用V8引擎来解析语句,并将其重建可在服务器上使用。所以严格上说node.js并不是服务器端运行的Javascript,而是可以在服务器端运行JavaScript语法的平台。 

    为什么要用node.js

    搞了半天就是一个新瓶装旧酒的东西,看起来除了一个新鲜的可以使用JavaScript语法,node.js没什么长处,为什么要用它而不是同样可以在服务器端运行的Java或C#呢?这要从node.js事件驱动和非阻塞I/O的特色谈起。关于事件驱动熟悉JavaScript的同学应该很熟悉了,node.js采用一系列“非阻塞”库来支持事件循环的方式。本质上就是为文件系统、数据库之类的资源提供接口,比如一个数据库访问,采用事件机制,发起请求之后,立即将进程交出,当数据返回后触发事件,再继续处理数据。

    在传统的阻塞I/O中其运行过程是这样的

    int num=query('select * from ......');
    
    print(num);

    ...................//无关语句

    print方法必须等待query方法返回结果,如果数据库出现网络连接故障,那么print方法就要等到超时才能执行,然后后面一些无关语句才能一次执行,而在非阻塞I/O中是这样的

    query('select * from...',callback(data){
      .............//相关语句
      print();
    });
    
    ..............//无关语句

    跟我们使用ajax,在回调函数中处理结果,但是不影响下面语句执行。 怪不得node.js要借用JavaScript来做此事,JavaScript的几个特性使它很胜任这项工作

    1. 事件机制
    2. 函数式编程,支持匿名函数,函数参数
    Node.js中代码是单进程、单线程执行的(我们写的代码是,但node.js本身不是有兴趣同学可以看看这个进一步了解),使用事件轮询机制和非阻塞I/O,在不新增额外线程的情况下对任务进行并行处理 。node.js解决了阻塞式编程浪费大量进程资源只是在等待,导致的大量内存和cpu的浪费问题,所以才敢宣称自己perfect for数据密集型的实时web 应用程序。

    如何安装

    nodejs的安装还是很简单的,尤其是现在安装包都把npm集成了进去,不用单独安装了,下载下安装包运行就可以了,另外想完整使用nodejs的话需要有C语言的编译环境、git和python,使用window的同学很能会稍微麻烦一些,需要搞定这些。对命令行情有独钟的同学可以看看How to Install Node.js

    npm是什么

    npm是node packaged modules的缩写,其实是一个nodejs的module的管理工具

    什么是module

    所谓module和java中的包的概念很类似,一些解决方案的集合,官方会提供核心的几个,第三方的很多

    如何安装第三方module

    因为nodejs的社区很活跃,有很多好用的第三方的包,我们可以在终端中使用npm的命令安装

    • npm install [-g] <name>:使用install指令可以把nodule下载安装的nodejs的全局的path处,不加的话会安装到当前路径
    • npm remove <name>:移除module
    • npm update <name>:更新 module

    还有一些常用命令可以看看npm常用命令

    第一个demo

     这些都搞定后我们就可以写传说中的hello world了。在任意目录建一个test.js文件

    console.log('Hello, World!');

    简单的一句话就可以,然后使用node命令运行

     这这这。。。太没技术含量了,看看官方给的demo,使用nodejs创建一个web server有多简单

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

     先运行一下服务器,按两次Ctrl+C退出

    使用浏览器访问一下

    就这么简单

    如何学习

    看到上面的demo是不是也对nodejs产生兴趣了呢,可是像我这样的懒人接触一门新语言的时候不知道该如何下手,难道又要去做个无聊的购物车神马的嘛,学习nodejs不用,nodejs为我们提供了一个小游戏一样的教程,就像个寻宝过程从零开始,没步都有一个任务和一下提示让你走的更远,上nodeschool下载然后开始寻宝吧,我就是被这小游戏迷住了,顺便秀一下我一天的战绩,每个任务都完成了

    看看解释就知道怎么做了,不过建议最开始run和verify结合使用,verify告诉你执行结果和预期结果,run会告诉你有哪些错误

     当然除了这些小游戏帮我们熟悉nodejs语法及使用,一些优秀的社区也可以帮我们很多

    CNode

    开源中国

    常见问题

  • 相关阅读:
    Spring(九)Spring中的两种自动代理
    Spring(八)Spring错题总结
    Spring(七)Spring中的四种增强和顾问
    SourceTree使用git
    Idea集成git
    SpringMVC--AbstractController抽象类限定请求提交
    SpringMVC处理器配置方式
    SpringMVC静态资源无法访问解决方案
    SpringMVC--视图解析器
    HandlerMapping执行流程
  • 原文地址:https://www.cnblogs.com/dolphinX/p/3474568.html
Copyright © 2020-2023  润新知