Node.js 发展史介绍与安装初体验

点击上方蓝字关注我们

图片

关于作者

作者简介:

公众号:Flowlet

最近打算做一个个人的Blog系统,用于技术交流与个人主页展示,起初打算通过Wordpress+VPS部署在云上,后来看了下腾讯云CVM价格比较贵就算是比较便宜的轻量应用服务器(Lighthouse)一年价格也需要1000人民币,其实也可以买一个玩玩,毕竟公司内部每个月还能抢100元腾讯云优惠券,可以给个人服务器进行续命。但是平时工作比较忙,Blog与公众号更新属实是属于反人性的东西,打算先基于Gitpages搭建一个免费的Blog主页,如果能够持续进行内容输出再考虑切换到个人服务器上。

本人主要是从事网络方向的研发工作,没有前后端开发经验,搭建个人Blog时需要用到Node.js,这里顺带学习并总结了一下。算是一个个人记录与知识分享。本文主要从以下几个方面介绍Node.js:

1、Node.js 介绍与发展史。

Part I:JavaScript与浏览器大战

Part II:JavaScript与Node.js

Part III:npm(Node Package Manger)介绍

2、Node.js 安装与配置。

3、Node.js 体验。

1、Node.js 介绍与发展史

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zmVSAPxd-1659932957095)(https://mmbiz.qpic.cn/mmbiz/h1VV7TJtQucjcTBOveSkhXRIjKuOVTB7MLQ6r4icCHia44WwE3UluuYqqBOfiavUia1z1CPUib1flQT4yIaXwWd5hjg/640?wx_fmt=jpeg)]

截止到2022年,Node.js已经13岁了,相比之下Javascript已经有26的历史了。Javascript是如何被创造出来的又是如何与Node.js联系在一起?

  • Part I:Javascript与浏览器大战。

图片

1995年网景公司招募了Brendan Eich(布兰登·艾奇),Eich在1995年5月仅花了10天的时间设计出了JavaScript的原型。在开发初期JavaScirpt被称为 Mocha,后又改为 LiveScript。

当时网景公司为了蹭Java的流量,也是为了吸引当时Java编程语言的开发人员能够通过JavaScripte进行开发。于是将这一门新的编程语言命名为JavaScript。

图片

1996年微软发布IE3,浏览器大战开始。当时微软已经是控制着操作系统市值超过2500亿美元的超级巨头,通过Windows+IE浏览器绑定的策略,到1998年IE已经占据浏览器市场50%以上的份额,微软击败网景公司后一统浏览器市场。

微软认为IE6浏览器已经非常完善,几乎没有可改进之处,于是解散了IE6开发团队。而Google却认为支持现代Web应用的新一代浏览器才刚刚起步,尤其是浏览器负责运行JavaScript的引擎性能还可提升10倍。

图片

先是Mozilla借助已壮烈牺牲的Netscape遗产在2002年推出了Firefox浏览器,紧接着Apple于2003年在开源的KHTML浏览器的基础上推出了WebKit内核的Safari浏览器,不过仅限于Mac平台。

随后,Google也开始创建自家的浏览器。他们也看中了WebKit内核,于是基于WebKit内核推出了Chrome浏览器。

图片

Chrome浏览器是跨Windows和Mac平台的,并且,Google认为要运行现代Web应用,浏览器必须有一个性能非常强劲的JavaScript引擎,于是Google自己开发了一个高性能JavaScript引擎,名字叫V8,以BSD许可证开源。

现代浏览器大战让微软的IE浏览器远远地落后了,因为他们解散了最有经验、战斗力最强的浏览器团队。回过头再追赶却发现,支持HTML5的WebKit已经成为手机端的标准了,IE浏览器从此与主流移动端设备绝缘。

  • Part II:Javascript与Node.js。

Node.js 是2009的时候由Ryan Dahl 开发的。Ryan 的本职工作是用 C++ 写高性能的Web服务器,后来他总结出一个经验,一个高性能服务器应该是满足“事件驱动,非阻塞 I/O”模型的。C++ 开发起来比较麻烦,于是 Ryan 就想找一种更高级的语言,以便快速开发。

可以说有两点促成了 Nodejs 的诞生。首先第一点,Ryan 发现 JS 语言本身的特点就是事件驱动并且是非阻塞 I/O 的。第二点,Chrome 的 JS 引擎,也就是 V8 引擎是开源的,而且性能特别棒。于是 Ryan 就基于 V8 开发了 Node.js 。

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,可以认为是JavaScript的语言解释器。

Node.js 最初的定位是提升 Ryan 自己的日常工作效率,也就是用来写服务器代码的,但是后来没有想到的是 Node.js 在前端领域却大放异彩。

Node.js 的诞生带给人们的是个大大的惊喜,传统上 Web 开发者,前端用 JS 写,但是写服务器端代码的时候还必须用另外一种语言,类似 Ruby/Java/PHP 等。但是 Node.js 出现之后,JS 前后通吃了。

  • Part III:npm介绍。

NPM全称Node Package Manager,是Node.js包管理工具。每个工具或者开发语言都有相应的包管理器,好比 Ubuntu 的 apt-get、Centos 的 yum、Java 的 Maven 仓库等等。Node.js 中目前最出名的包管理器为 NPM 同时也是生态最好的包管理工具。

由于新版的Node.js已经集成了npm,可以通过输入 “npm -v” 来测试是否安装成功。

2、Node.js安装与配置

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DlTmWL35-1659932957098)(https://mmbiz.qpic.cn/mmbiz/h1VV7TJtQucjcTBOveSkhXRIjKuOVTB7MLQ6r4icCHia44WwE3UluuYqqBOfiavUia1z1CPUib1flQT4yIaXwWd5hjg/640?wx_fmt=jpeg)]

由于Windows10电脑已经安装了WSL2,所以基于Ubuntu环境安装Node.js。

1、通过Windows termina登录WSL2安装的ubuntu

图片

2、安装通过apt-get安装node.js

输入:sudo apt-get install node.js

图片

报错:

E: Unable to locate package node.js
E: Couldn't find any package by glob 'node.js'

更新apt-get源端,然后再进行安装。

sudo apt-get update
sudo apt-get install node.js

查看node.js是否安装成功:

npm -v

图片

3、安装通过apt-get安装npm

sudo apt-get install npm

查看npm是否安装成功:

图片

3、Node.js体验

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LcDjL5pO-1659932957102)(https://mmbiz.qpic.cn/mmbiz/h1VV7TJtQucjcTBOveSkhXRIjKuOVTB7MLQ6r4icCHia44WwE3UluuYqqBOfiavUia1z1CPUib1flQT4yIaXwWd5hjg/640?wx_fmt=jpeg)]

之前我们编写的JavaScript代码都是在浏览器中运行,后面我们编写的JavaScript代码将在Node.js环境中运行,Node.js运行方式与Python类似,分为命令行交互模式运行与脚本模式运行。

1、通过命令行交互模式运行Node.js

在命令行下键入node,进入命令行模式:

图片

运行算数运算1+1:

图片

输出"hello,world":

图片

输入".exit"退出node命令行模式:

图片

2、通过脚本模式运行Node.js

如果我们使用 PHP 来编写后端的代码时,需要 Apache 或者 Nginx 的 HTTP 服务器,并配上 mod_php5 模块和 php-cgi。

不过对 Node.js 来说,概念完全不一样了。使用 Node.js 时,我们不仅仅 在实现一个应用,同时还实现了整个 HTTP 服务器。

Node.js 实现Http应用主要由以下几部分组成:

  • (1)引入 required 模块:我们可以使用 require 指令来载入 Node.js 模块。
var http = require("http");

我们使用 require 指令来载入 http 模块,并将实例化的 HTTP 赋值给变量 http。

  • (2)创建服务器:服务器可以监听客户端的请求,类似于 Apache 、Nginx 等 HTTP 服务器。

文件目录下创建一个叫 server.js 的文件,使用 http.createServer() 方法创建服务器。

由于使用WSL部署的Node.js环境, 使用listen 方法绑定 WSL上的172.23.4.189的8888 端口。

图片

函数通过 request, response 参数来接收和响应数据。

var http = require('http');
http.createServer(function (request, response) {
// 发送 HTTP 头部
// HTTP 状态值: 200 : OK    
// 内容类型: text/plain
response.writeHead(200, {'Content-Type': 'text/plain'});

// 发送响应数据 "Hello World"    
response.end('Hello World\n');

}).listen(8888, '172.23.4.189');

// 终端打印如下信息
console.log('Server running at http://172.23.4.189:8888/');
  • (3)接收请求与响应请求的服务器很容易创建,客户端可以使用浏览器或终端发送 HTTP 请求,服务器接收请求后返回响应数据。

  • (4)WSL中使用 node 命令执行以上的代码:

    node server.js
    

图片

  • (5)Windows中浏览器输入http://172.23.4.189:8888/构造Http请求:

图片

可以看到在浏览器中回显Hello World文字。

(正文完)

end

Reference:

https://www.runoob.com/nodejs/nodejs-http-server.html

https://zhuanlan.zhihu.com/p/47822968

https://nodejs.org/zh-cn/

转载与投稿

文章转载需注明:文章来源公众号:Flowlet

欢迎云计算、SDN、NFV、互联网IT等方向的大牛投稿。

后台回复【加群】,加入高手如云群,探讨技术。

| 温馨提示 |

欢迎分享、收藏、点赞、转发。

点个在看你最好看

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值