五个最佳案例带你解读Node.js前后之道_第1页
五个最佳案例带你解读Node.js前后之道_第2页
五个最佳案例带你解读Node.js前后之道_第3页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

2、减少了多线程程序设计的复杂性,进而提高了开发效率。Node.js 的特点1、一个Javascript 运行环境2、依赖于Chrome V8 引擎进行代码解释3、事件驱动4、非阻塞I/O5、轻量、可伸缩,适于实时数据交互应用6、单进程,单线程Node.js 能做什么?1、具有复杂逻辑的网站2、 基于社交网络的大规模Web应用;3、Web Socket 服务器(页游, web IM );4、TCP/UDP 套接字应用程序;5、命令行工具;6、交互式终端程序;7、带有图形用户界面的本地应用程序;8、单元测试工具;9、客户端JavaScript编译器Node.js 架构事件循环NodeJs执行模型:单

3、线程Event Loop当应用请求发生时,首先进入V8引擎,然后进入到事件队列,可以理解为他们在不断地在循环,看是否有任务,产生任务就去执行。上图是单线程模型。NPM后端在开发其他语言时,都有一些模块的概念或者第三方提供了很实用的小模块。同样,Node.js当时出来的时候也有这样一个仓库。这个仓库就是专门用来管理中国开发者的一个贡献的模块,而且发展非常的快。同样,前端有一些脚手件,在服务器这边运行的有debug,express ,express-session , thrift,依托这个插件做 thrift 相关的事情,images 其他的一 些你想的到的插件,都是可以从它找到。架构体系云组件

4、资源NginxHTTP厂1Node节点1厂1Node节点2Node节点3Java节点10Java节点2ses;sionredis集群sionJava节点3Fhrift上图是个推部分 WEB平台的架构体系,个推有一套云组进资源,通过Nginx作为一个分发,Node可以有多个节点,通过session进入。每一个Node都有模式,相信大家在部署的时候肯定不可能部署一个节点,部署一个节点,否则这个节点挂了就是挂了。Thrift 使用1、定义接口/ errorstruct GeError 1: 132 errorCode,2: string errorMsg,3: string errorSeq/ co

5、mmon response struct Response 1: bool success,2: GeError error/ / common serviceservice Testservice Response testDoSth(1: 吕tring name) 2、编译,生成对应的包,并上传到相应的库中3、在Node中使用,如下:/引入必要的依赖flh M «/引入编译好的方法var thrift = require("XXX-thrift/TestService");/其它代码thrift.nam巳r function (err, data) /TODO

6、 sth);注意:这里有个坑thrift中有个基本类型叫做double (64位浮点数)。当定义成这个类型时,数据从java过来到Node 会变成全是0。解决方案定义成string 类型,之后特事特办,如必要则在Node 处再转成浮点数,或者直接由页面端处理。IP 负载(IP Load Bala nee )负载均衡分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。原生中其并没有负载均衡的机制,但我们可以采用动态代理的设计模式,基于thrift elie nt ,利用JS的原型链来实现。Java节点。均衡的方式有很多种,

7、我们使用轮询机制来实现访问多个sessi on 管理Node本身并无session机制,我们可以使用 express-session包来实现,同时通过redis来存储 session。连接池传统读取数据库方式:连接池需要做什么?1、 连接预热(启动时自动打开 n个连接以供使用)2、使用例如轮转法均匀分发连接请求3、当池中的连接即将耗尽得时候动态产生新的连接4、当池中的连接一段时间没有被调用的时候,自动释放连接5、自动丢弃 已经坏掉的 连接6、系统关闭的时自动释放所有连接基于此,我们也可以借助几个插件包 (如gen eric-pool (n ode-pool )、node-thrift-pool

8、 , 当然,如果你直接Node连接的DB ,基本上那个包里面也会支持连接池)在Node使用连接池。使用示例var thrift = require( t.nri ft/' , Service = require(11, /gen-node js/ServiceH) f Types = require("/gen-nodejs/types")t thriftPool require("node-thrift-pool">var thriftclient = thriltPoolI thrift t Service, ( host:Localh

9、ost' tport t 9090host - Required -The hOBtof the thrift server to connect toport - Required -The porto£ the thrift server to connect tomax 亡口nnect ions -Defaulh:1 - Max nuHLbex of Connections to k亡ep口penatminconnections -Default:0 - Min number of connections to keepopenatidle_timeout - Defaultr 30QQQ - Time (ms) to wait until closing idle com利用Node可以做的事情1、做一些灰色地带的事情利用Node可以做一些灰色地带的事情,因为它拥有前端的优点,可以异步,发起异步请求。给开发者带来很大的好处。不过,你需要管理好你的类型。如果说类型自己如果没有管理好就是会出现一些问题。同时它也可以做后端的一些事情。比如说连接池等等。2、模块更加分明3、可前可后便于分工从浏览器过来的数据,通过Node把这一层数据转化成java需要的一种数据结构,就可以使得分工更加明晰。4、共用表单输入验证如果你在写系统的时候, 出于安全考虑,无论浏览器这边

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论