五个最佳案例带你解读 Node.js 的前后之道

Node.js 是什么?

Node.js 采用 C++语言编写而成,浏览器内核 V8 做为执行引擎; Node 不是 JS 应用、而是一个 Javascript 的运行环境。 Node 保留了前端浏览器 js 的接口,没有改写语言本身的任何特性,依旧基于作用域和原型链。

Node.js 是一个为实时 Web ( Real-time Web )应用开发而诞生的平台,它从诞生之初就充分考虑了在实时响应、超大规模数据要求下架构的可扩展性。这使得它摒弃了传统平台依靠多线程来实现高并发的设计思路,而采用了单线程、异步式 I/O 、事件驱动式的程序设计模型。这些特性不仅带来了巨大的性能提升,还减少了多线程程序设计的复杂性,进而提高了开发效率。

Node.js 的特点

1 、一个 Javascript 运行环境 
2 、依赖于 Chrome V8 引擎进行代码解释 
3 、事件驱动 
4 、非阻塞 I/O 
5 、轻量、可伸缩,适于实时数据交互应用 
6 、单进程,单线程

Node.js 能做什么?

1 、具有复杂逻辑的网站 
2 、基于社交网络的大规模 Web 应用; 
3 、 Web Socket 服务器(页游, web IM ); 
4 、 TCP/UDP 套接字应用程序; 
5 、命令行工具; 
6 、交互式终端程序; 
7 、带有图形用户界面的本地应用程序; 
8 、单元测试工具; 
9 、客户端 JavaScript 编译器

Node.js 架构

事件循环

NodeJs 执行模型: 单线程 Event Loop

当应用请求发生时,首先进入 V8 引擎,然后进入到事件队列,可以理解为他们在不断地在循环,看是否有任务,产生任务就去执行。上图是单线程模型。

NPM

后端在开发其他语言时,都有一些模块的概念或者第三方提供了很实用的小模块。同样, Node.js 当时出来的时候也有这样一个仓库。这个仓库就是专门用来管理中国开发者的一个贡献的模块,而且发展非常的快。同样,前端有一些脚手件,在服务器这边运行的有 debug , express , express-session , thrift ,依托这个插件做 thrift 相关的事情, images 其他的一些你想的到的插件,都是可以从它找到。

架构体系

上图是个推部分 WEB 平台的架构体系,个推有一套云组进资源,通过 Nginx 作为一个分发, Node 可以有多个节点,通过 session 进入。每一个 Node 都有模式,相信大家在部署的时候肯定不可能部署一个节点,部署一个节点,否则这个节点挂了就是挂了。

Thrift 使用

1 、定义接口

2 、编译,生成对应的包,并上传到相应的库中 
3 、在 Node 中使用,如下:

注意:这里有个坑

thrift 中有个基本类型叫做 double ( 64 位浮点数)。当定义成这个类型时,数据从 java 过来到 Node 会变成全是 0 。

解决方案

定义成 string 类型,之后特事特办,如必要则在 Node 处再转成浮点数,或者直接由页面端处理。 
IP 负载( IP Load Balance )

负载均衡

分摊到多个操作单元上进行执行,例如 Web 服务器、 FTP 服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。 
原生中其并没有负载均衡的机制,但我们可以采用动态代理的设计模式,基于 thrift client ,利用 JS 的原型链来实现。 
均衡的方式有很多种,我们使用轮询机制来实现访问多个 Java 节点。

session 管理

Node 本身并无 session 机制,我们可以使用 express-session 包来实现,同时通过 redis 来存储 session 。

连接池

传统读取数据库方式:

连接池需要做什么?

1 、连接预热 (启动时自动打开 n 个连接以供使用) 
2 、使用 例如 轮转法 均匀分发 连接请求 
3 、当池中的连接即将耗尽得时候动态产生新的连接 
4 、当池中的连接一段时间没有被调用的时候,自动释放连接 
5 、自动丢弃 已经坏掉的 连接 
6 、系统关闭的时自动释放所有连接

基于此,我们也可以借助几个插件包(如 generic-pool ( node-pool )、 node-thrift-pool ,当然,如果你直接 Node 连接的 DB ,基本上那个包里面也会支持连接池)在 Node 使用连接池。

使用示例

利用 Node 可以做的事情

1 、做一些灰色地带的事情 
利用 Node 可以做一些灰色地带的事情,因为它拥有前端的优点,可以异步,发起异步请求。给开发者带来很大的好处。不过,你需要管理好你的类型。如果说类型自己如果没有管理好就是会出现一些问题。同时它也可以做后端的一些事情。比如说连接池等等。 
2 、模块更加分明 
3 、可前可后便于分工 
从浏览器过来的数据,通过 Node 把这一层数据转化成 java 需要的一种数据结构,就可以使得分工更加明晰。 
4 、共用表单输入验证 
如果你在写系统的时候,出于安全考虑,无论浏览器这边做了多少验证,你都要做输入验证。传统模式下是需要 java 同学写一份,前端同学写一份。因为 Node 跟 java 都是部署在服务器集群或者一个区域,你可以相信这两边之间一个数据。来自浏览器的验证,就可以共用表单输入验证,达到节省成本的目的。

以上内容来自个推 web 服务首席架构师姜季廷在 3 月 12 日 SegmentFault D-Day 北京:后端的演讲整理而成。

本文来自https://www.v2ex.com/t/266827

时间: 2024-08-06 11:54:37

五个最佳案例带你解读 Node.js 的前后之道的相关文章

五个最佳案例带你解读Node.js的前后之道

Node.js 是什么? Node.js采用C++语言编写而成,浏览器内核V8做为执行引擎:Node不是JS应用.而是一个Javascript的运行环境.Node保留了前端浏览器js的接口,没有改写语言本身的任何特性,依旧基于作用域和原型链. Node.js 是一个为实时Web(Real-time Web)应用开发而诞生的平台,它从诞生之初就充分考虑了在实时响应.超大规模数据要求下架构的可扩展性.这使得它摒弃了传统平台依靠多线程来实现高并发的设计思路,而采用了单线程.异步式I/O.事件驱动式的程

面向Web Cloud的HTML5 App开发实战:Browser&HTML5&CSS3&PhoneGap&jQuery Mobile& WebSocket&Node.js(3天)

课程简介: 王家林老师(联系邮箱[email protected] 电话:18610086859 QQ:1740415547 微信号:18610086859) 22个HTML5主题一次性贯穿HTML5的一切技术: 一网打尽HTML5时代Device.(设备端).Browser(浏览器)和Cloud(浏览器)的所有技术: 以浏览器定制技术为基础,通晓HTML5+CSS3+PhoneGap+Web Socket +jQuery Mobile +Node.js等HTML5的六大核心技术: 最新研发的H

让前端猪猪飞起来的Node.js

前端猪猪飞飞 传统前端猪猪大多数做的事情就是页面的布局.渲染和动画效果等工作,玩弄的总是一个网页壳,因为没有后台支持,这总让前端猪猪觉得有点不爽.而Node.js的出现,却让前端猪猪们翱翔于蓝天,因为可以使用js来调用数据库,文件等后台操作,瞬间感觉猪猪也能飞,也能吊炸天. Node.js是第三方js库 大多数不认识Node.js的人会第一直觉感觉这不就是一个第三方js库吗?我只想说"呵呵"(其实我刚学那时候也这样认为). 直接上Node.js官方解释: Node.js是一个基于Chr

如何快速搭建node.js项目,app.js详解

请参照:https://www.cnblogs.com/yanhua2017/p/6385494.html 前提安装了node.js 1.npm install express express-generator -g 安装express 2.express --hbs myNode 快速构建nodejs项目 myNode3.npm install 安装依赖4.node bin/www || npm start 启动服务   访问localhost:3000   ||   http://loca

Practical Node.js (2018版) 第5章:数据库 使用MongoDB和Mongskin。

Persistence with MongoDB and Mongoskin https://github.com/azat-co/practicalnode/blob/master/chapter5/chapter5.md 学习mongodb的官方网站: https://docs.mongodb.com/manual/tutorial/getting-started/ 我真的喜欢使用MongoDB with Node.因为这个数据库有JavaScript interface, 并使用JSON-

10个最佳Node.js企业应用案例:从Uber到LinkedIn

译者按: Node.js 8已经发布了,NPM模块每周下载量早已超过10亿,从Uber到LinkedIn都在使用Node.js,谁说JavaScript不能写后台? 原文: 10 best Node.js app examples for enterprises, with metrics 译者: Fundebug 为了保证可读性,本文采用意译而非直译.另外,本文版权归原作者所有,翻译仅用于学习. 小编推荐:Fundebug专注于JavaScript.微信小程序.微信小游戏,Node.js和Ja

为什么我要用 Node.js? 案例逐一介绍

介绍 JavaScript 高涨的人气带来了很多变化,以至于如今使用其进行网络开发的形式也变得截然不同了.就如同在浏览器中一样,现在我们也可以在服务器上运行 JavaScript ,从前端跨越到后端,这样巨大的反差让人难以想象,因为仅仅在几年前 Javascript 还如同 Flash 或者 Java applet 那样嵌入网页在沙箱环境中运行. 在深入Node.js之前,你可能需要阅读和了解使用跨栈式JavaScript(JavaScript across the stack)带来的好处,它统

10+ 最佳的 Node.js 教程和实例

如果你正在找Node.js的学习资料及指南,那么请继续(阅读),我们的教程将会覆盖即时聊天应用.API服务编写.投票问卷应用.人物投票APP.社交授权. Node.js on Raspberry Pi等等. 以下是Node.js入门的简单介绍,如果你对Node.js略有了解可以直接跳过此部分. 那什么是Node.js呢? Node.js是迄今运用最多的服务端JavaScript运行时环境,使用JavaScript开发跨平台的实时WEB应用. Node.js基于Google的V8 JavaScri

node.js require() 源码解读

时至今日,Node.js 的模块仓库 npmjs.com ,已经存放了15万个模块,其中绝大部分都是 CommonJS 格式.这种格式的核心就是 require 语句,模块通过它加载.学习 Node.js ,必学如何使用 require 语句.本文通过源码分析,详细介绍 require 语句的内部运行机制,帮你理解 Node.js 的模块机制. 一.require() 的基本用法分析源码之前,先介绍 require 语句的内部逻辑.如果你只想了解 require 的用法,只看这一段就够了.下面的