描述
开 本: 16开纸 张: 胶版纸包 装: 平装-胶订是否套装: 否国际标准书号ISBN: 9787121335228
产品特色
编辑推荐
• Node.js 的开发方式:如何使用正确的思维方式去解决一个 Node.js 开发设计问题。比如你会学习到,传统设计模式在 Node.js 开发中的不同体现,或者如何设计提供单一功能的模块。
• 一整套解决常见 Node.js 设计和编码问题的设计模式:你会学习到一整套像“瑞士军刀”一样功能多样、实用的设计模式,让你能即学即用,解决日常遇到的程序开发和设计问题。
• 如何编写模块化、高效率的 Node.js 程序:你将会理解开发大规模并且结构组织合理的 Node.js 程序的基本方法,并能运用这些方法去解决不属于现有设计模式范畴的新问题。
• 真实项目中用到的库和技术:LevelDb、Redis、RabbitMQ、ZMQ 及 Express 等用来作为示例阐述某个设计模式或者方法,让例子更加实用,对生态系统及它解决问题的方法有所了解。
内容简介
本书通过大量示例形象地阐述了 Node.js 的哲学思想和设计模式。内容主要由六部分组成:Node 核心思想、基础设计模式、异步控制流模式、流编程、Node.js 的传统设计模式和特有设计模式、通用编程的 Web 应用以及处理复杂实际问题的高级编程技巧。这是一本值得深入品读的书籍,读者若具备一些软件设计的理论知识会有助于理解书中提出的概念,中级 Node.js 开发者也会从本书有所收获。本书尤其适用于已经接触过 Node.js 并且想在效率、设计质量和可扩展性方面获得提升的开发者。
目 录
目录
第1 章欢迎来到Node.js 平台 1
Node.js 的哲学思想 2
小核心 2
小模块 2
小接触面 3
简单和实用3
认识Node.js 6 和ES2015 4
let 和const 关键字 5
箭头函数 6
类语法 8
增强的对象字面量 10
Map 和Set 集合 11
WeakMap 和WeakSet 集合 13
模板字面量 14
其他ES2015 特性 14
Reactor 模式 15
I/O 是缓慢的 15
阻塞I/O 15
非阻塞I/O 16
事件多路分解器 17
Reactor 模式简介 19
Node.js-libuv 的非阻塞I/O 引擎 20
Node.js 的秘诀 21
总结 21
第2 章Node.js 基础设计模式 23
回调模式 24
CPS(Continuation Passing Style) 24
同步或异步 26
Node.js 回调约定 31
模块系统及其模式 34
揭示模块模式 34
Node.js 模块解释 35
模块定义模式 42
观察者模式 49
EventEmitter 类 49
创建和使用EventEmitter 50
传播错误 51
使任何对象可观察 51
同步和异步事件 53
EventEmitter 与回调 54
组合回调和EventEmitter 55
总结 55
第3 章异步控制流模式之回调函数 56
异步编程的困难 56
创建一个简单的网络蜘蛛 57
回调地狱 59
使用纯JavaScript 60
回调规则 60
应用回调规则 61
顺序执行 63
并行执行 68
有限制的并行执行 73
async 库 77
顺序执行 78
并行执行 81
有限制的并行执行 81
总结 83
第4 章异步控制流模式之ES2015 84
promise 84
什么是promise 85
Promises/A 实现 87
Node.js 风格函数的promise 化 88
顺序执行 90
并行执行 93
有限制的并行执行 93
在公共API 中暴露callback 和promise 95
generator 97
generator 基础 97
generator 的异步控制流 100
顺序执行 104
并行执行 106
有限制的并行执行 108
使用Babel 的async await 111
安装和运行Babel 112
比较 113
总结 114
第5 章流编程 115
流的重要性 115
缓冲和流 116
空间效率 117
时间效率 118
组合性 121
开始学习流 122
流的分类 122
可读流 123
可写流 127
双向流(Duplex stream) 132
变换流 132
使用管道拼接流 135
使用流处理异步流程 137
顺序执行 138
无序并行执行 139
无序有限制的并行执行 143
顺序并行执行 145
管道模式 146
组合流 146
复制流 149
合并流 150
复用和分解 152
总结 159
第6 章设计模式 160
工厂模式 161
创建对象的通用接口 161
一种封装的机制 162
构建一个简单的代码分析器 164
可组合的工厂函数 166
扩展 169
揭示构造函数 170
只读事件触发器 171
扩展 172
代理模式 173
实现代理模式的方法 174
不同方法的比较 176
创建日志记录的写入流 176
生态系统中的代理模式——函数钩子与面向行为编程(AOP) 178
第1 章欢迎来到Node.js 平台 1
Node.js 的哲学思想 2
小核心 2
小模块 2
小接触面 3
简单和实用3
认识Node.js 6 和ES2015 4
let 和const 关键字 5
箭头函数 6
类语法 8
增强的对象字面量 10
Map 和Set 集合 11
WeakMap 和WeakSet 集合 13
模板字面量 14
其他ES2015 特性 14
Reactor 模式 15
I/O 是缓慢的 15
阻塞I/O 15
非阻塞I/O 16
事件多路分解器 17
Reactor 模式简介 19
Node.js-libuv 的非阻塞I/O 引擎 20
Node.js 的秘诀 21
总结 21
第2 章Node.js 基础设计模式 23
回调模式 24
CPS(Continuation Passing Style) 24
同步或异步 26
Node.js 回调约定 31
模块系统及其模式 34
揭示模块模式 34
Node.js 模块解释 35
模块定义模式 42
观察者模式 49
EventEmitter 类 49
创建和使用EventEmitter 50
传播错误 51
使任何对象可观察 51
同步和异步事件 53
EventEmitter 与回调 54
组合回调和EventEmitter 55
总结 55
第3 章异步控制流模式之回调函数 56
异步编程的困难 56
创建一个简单的网络蜘蛛 57
回调地狱 59
使用纯JavaScript 60
回调规则 60
应用回调规则 61
顺序执行 63
并行执行 68
有限制的并行执行 73
async 库 77
顺序执行 78
并行执行 81
有限制的并行执行 81
总结 83
第4 章异步控制流模式之ES2015 84
promise 84
什么是promise 85
Promises/A 实现 87
Node.js 风格函数的promise 化 88
顺序执行 90
并行执行 93
有限制的并行执行 93
在公共API 中暴露callback 和promise 95
generator 97
generator 基础 97
generator 的异步控制流 100
顺序执行 104
并行执行 106
有限制的并行执行 108
使用Babel 的async await 111
安装和运行Babel 112
比较 113
总结 114
第5 章流编程 115
流的重要性 115
缓冲和流 116
空间效率 117
时间效率 118
组合性 121
开始学习流 122
流的分类 122
可读流 123
可写流 127
双向流(Duplex stream) 132
变换流 132
使用管道拼接流 135
使用流处理异步流程 137
顺序执行 138
无序并行执行 139
无序有限制的并行执行 143
顺序并行执行 145
管道模式 146
组合流 146
复制流 149
合并流 150
复用和分解 152
总结 159
第6 章设计模式 160
工厂模式 161
创建对象的通用接口 161
一种封装的机制 162
构建一个简单的代码分析器 164
可组合的工厂函数 166
扩展 169
揭示构造函数 170
只读事件触发器 171
扩展 172
代理模式 173
实现代理模式的方法 174
不同方法的比较 176
创建日志记录的写入流 176
生态系统中的代理模式——函数钩子与面向行为编程(AOP) 178
ES2015 中的Proxy 对象 178
扩展 180
装饰者模式(Decorator) 180
实现装饰者模式的方法 181
装饰一个LevelUP 数据库 182
扩展 185
适配器模式(Adapter) 185
通过文件系统API 来使用LevelUP 数据库 186
扩展 189
策略模式(Strategy) 189
支持多种格式的配置对象 190
扩展 193
状态模式 193
实现一个基本的自动防故障套接字 194
模板模式(Template) 199
配置管理器模板 199
扩展 201
中间件(Middleware) 202
Express 中的中间件 202
设计模式中的中间件 203
为?MQ 创建中间件框架 204
在Koa 中使用生成器的中间件 210
命令模式(Command) 213
灵活的设计模式 214
总结 218
第7 章连接模块 220
模块和依赖 221
Node.js 中最常见的依赖 221
内聚和耦合 222
有状态的模块 222
连接模块模式 224
硬编码依赖 224
依赖注入 229
服务定位器 234
依赖注入容器 239
连接插件 243
插件作为包 243
扩展点 245
插件控制与应用程序控制的扩展 245
实现注销插件 248
总结 256
第8 章通用JavaScript 的Web 应用程序 257
与浏览器端共享代码 258
共享模块 258
Webpack 简介 262
Webpack 的魔力 263
Webpack 的优点 264
使用ES2015 和Webpack 265
跨平台开发基础 267
运行时代码分支 268
构建时代码分支 269
模块交换 271
用于跨平台开发的设计模式 273
React 介绍 274
React 组件 275
JSX 是什么 277
配置Webpack 以实现JSX 转换 279
在浏览器中渲染 280
React 路由库 281
创建通用JavaScript 应用程序 286
创建可用的组件 287
服务端渲染 289
通用渲染和路由 293
通用数据检索 294
总结 304
第9 章高级异步编程技巧 305
需要异步初始化的模块 305
规范解决方案 306
预初始化队列 307
题外话 311
异步批处理和缓存 312
实现没有缓存或批处理的服务器 312
异步请求批处理 314
异步请求缓存 316
使用promise 进行批处理和缓存 319
运行CPU 绑定的任务 322
解决子集和问题 322
交叉使用setImmediate 325
使用多进程 328
总结 335
第10 章扩展与架构模式 336
应用程序扩展介绍 337
扩展Node.js 应用程序 337
可扩展性的三个维度 337
克隆和负载均衡 339
集群模块 340
处理有状态通信 348
使用反向代理进行扩展 350
使用服务注册表 354
对等负载均衡 360
分解复杂的应用程序 362
单体式架构 362
微服务架构 364
微服务架构中的集成模式 367
总结 372
第11 章消息传递与集成模式 374
消息系统的基础 375
单向和请求/应答模式 375
消息类型 376
异步消息和队列 377
对等或基于代理的消息 378
发布/订阅模式 379
构建简约的实时聊天应用程序 380
使用Redis 作为消息代理 383
使用?MQ 对等发布/订阅 385
持久订阅者 389
管道和任务分配模式 396
MQ 扇出/扇入模式 397
使用AMQP 实现管道和竞争消费者模式 401
请求/应答模式 406
关联标识符 406
返回地址 410
总结 415
扩展 180
装饰者模式(Decorator) 180
实现装饰者模式的方法 181
装饰一个LevelUP 数据库 182
扩展 185
适配器模式(Adapter) 185
通过文件系统API 来使用LevelUP 数据库 186
扩展 189
策略模式(Strategy) 189
支持多种格式的配置对象 190
扩展 193
状态模式 193
实现一个基本的自动防故障套接字 194
模板模式(Template) 199
配置管理器模板 199
扩展 201
中间件(Middleware) 202
Express 中的中间件 202
设计模式中的中间件 203
为?MQ 创建中间件框架 204
在Koa 中使用生成器的中间件 210
命令模式(Command) 213
灵活的设计模式 214
总结 218
第7 章连接模块 220
模块和依赖 221
Node.js 中最常见的依赖 221
内聚和耦合 222
有状态的模块 222
连接模块模式 224
硬编码依赖 224
依赖注入 229
服务定位器 234
依赖注入容器 239
连接插件 243
插件作为包 243
扩展点 245
插件控制与应用程序控制的扩展 245
实现注销插件 248
总结 256
第8 章通用JavaScript 的Web 应用程序 257
与浏览器端共享代码 258
共享模块 258
Webpack 简介 262
Webpack 的魔力 263
Webpack 的优点 264
使用ES2015 和Webpack 265
跨平台开发基础 267
运行时代码分支 268
构建时代码分支 269
模块交换 271
用于跨平台开发的设计模式 273
React 介绍 274
React 组件 275
JSX 是什么 277
配置Webpack 以实现JSX 转换 279
在浏览器中渲染 280
React 路由库 281
创建通用JavaScript 应用程序 286
创建可用的组件 287
服务端渲染 289
通用渲染和路由 293
通用数据检索 294
总结 304
第9 章高级异步编程技巧 305
需要异步初始化的模块 305
规范解决方案 306
预初始化队列 307
题外话 311
异步批处理和缓存 312
实现没有缓存或批处理的服务器 312
异步请求批处理 314
异步请求缓存 316
使用promise 进行批处理和缓存 319
运行CPU 绑定的任务 322
解决子集和问题 322
交叉使用setImmediate 325
使用多进程 328
总结 335
第10 章扩展与架构模式 336
应用程序扩展介绍 337
扩展Node.js 应用程序 337
可扩展性的三个维度 337
克隆和负载均衡 339
集群模块 340
处理有状态通信 348
使用反向代理进行扩展 350
使用服务注册表 354
对等负载均衡 360
分解复杂的应用程序 362
单体式架构 362
微服务架构 364
微服务架构中的集成模式 367
总结 372
第11 章消息传递与集成模式 374
消息系统的基础 375
单向和请求/应答模式 375
消息类型 376
异步消息和队列 377
对等或基于代理的消息 378
发布/订阅模式 379
构建简约的实时聊天应用程序 380
使用Redis 作为消息代理 383
使用?MQ 对等发布/订阅 385
持久订阅者 389
管道和任务分配模式 396
MQ 扇出/扇入模式 397
使用AMQP 实现管道和竞争消费者模式 401
请求/应答模式 406
关联标识符 406
返回地址 410
总结 415
前 言
很多人认为Node.js 的出现是Web 开发领域十年内最大的变化,它就像是游戏规则的改变者。之所以被喜爱不仅是因为技术上的出众能力,同时也因为它带给Web 开发新的思维方式。
首先,Node.js 应用是使用JavaScript 语言编写的,而JavaScript 又是唯一被绝大多数Web 浏览器原生支持的编程语言。该特性使得单语言应用栈以及服务端、客户端代码共享成为可能。Node.js 本身也促进了JavaScript 语言的兴起和发展。人们意识到,在服务端使用JavaScript并不像在浏览器端使用它那样糟糕,并且人们将慢慢喜欢上它的编程思维和它混合的天性,即面向对象和函数式编程的结合。
其次,单线程和异步架构也是Node.js 带来的革命性变化。除了性能和可扩展性方面的明显优势外,其改变了开发者处理程序并发和并行的方式。队列取代了互斥锁,回调函数和事件机制取代了多线程,因果关系取代了同步性。
最后也是最重要的一点,Node.js 拥有一套完整的生态系统:npm 包管理器、不断增长的模块数量、热情活跃的开发社区,以及基于简单、实用主义和极端模块化而产生的独特文化。
然而,因为这些特性,Node.js 开发给人一种与其他服务端语言开发非常不一样的感受,刚开始接触Node.js 的开发者,会经常困惑于如何有效地解决一些最常见的设计和代码编写问题。常见的问题有:“如何组织代码?”“设计这个系统的最好方法是什么?”“怎样使我的程序更加模块化?”“我该怎样高效实现大量的异步调用?”“我该如何确保我的程序随着规模增大会一直稳定运行,不会崩溃?”或者更简单的问题,“Node.js 开发的正确方式是什么?”幸运的是,Node.js 已经成为一个非常成熟的开发平台,以上大部分问题都能通过设计模式、被证明有效的编码技巧或者他人提供的经验来解决。本书的目的就是指导你学习并掌握Node.js 开发的一些设计模式、编码技巧和实践经验,告诉你解决这些常见问题的有效方法并教会你如何从这些方法出发,解决你自己遇到的特定问题。
通过阅读本书,你将掌握以下这些内容:
• Node.js 的开发方式如何使用正确的思维方式去解决一个Node.js 开发设计问题。比如你会学习到,传统设计模式在Node.js 开发中的不同体现,或者如何设计提供单一功能的模块。
• 一整套解决常见Node.js 设计和编码问题的设计模式你会学习到一整套像“瑞士军刀”一样功能多样、实用的设计模式,并且你能即学即用,解决日常遇到的程序开发和设计问题。
• 如何编写模块化、高效率的Node.js 程序你将会了解开发大规模并且结构组织合理的Node.js 程序的基本方法,并能运用这些方法去解决不属于现有设计模式范畴的新问题。
在本书中,你会看到一些真实项目中用到的库和技术,比如LevelDb、Redis、RabbitMQ、ZMQ 及Express 等。这些会用来作为示例阐述某个设计模式或者方法,除了让例子更加实用外,它们同时会让你对Node.js 的生态系统以及它解决问题的一套方法有所了解。无论你正使用或打算在你的工作、非正式项目或者开源项目中使用Node.js,认识和使用众所周知的设计模式和技术能够让你通过一种通用的语言和他人共享你的代码和设计,不仅如此,这还会帮助你更好地了解Node.js 的未来,以及知道如何为其发展贡献自己的一份力量。
各章介绍
第1 章,欢迎来到Node.js 平台,本章通过讲解Node.js 本身核心的设计模式来介绍Node.js 程序的设计,包括Node.js 的生态系统、编程思想,以及Node.js V6 版本、ES2015 和Reactor 模式的简单介绍。
第2 章,Node.js 基础设计模式,开始介绍Node.js 异步编程和设计模式,讨论和比较了回调函数与事件触发器(观察者模式)。本章还介绍了Node.js 的模块系统和相关模块的设计模式。
第3 章,异步控制流模式之回调函数,介绍了系列用于有效处理Node.js 中的异步控制流的模式和技术。这一章将教你怎样使用纯JavaScript 和异步库来缓解“回调地狱”的问题。
第4 章,异步控制流模式之ES2015 ,介绍了Promise、Generator 和async-await 的异步控制流的探索进展。
第5 章,流编程,深度挖掘Node.js 中最重要的模式之一:流。本章将向你展示如何处理数据流交换及如何将它们组合成不同的布局。
第6 章,设计模式,本章涉及一个有争议的话题:Node.js 的传统设计模式。介绍了最流行的传统设计模式,并展示了它们在Node.js 中的应用。同时也介绍了一些JavaScript 和Node.js中独有的新设计模式。
第7 章,连接模块,分析了将多个模块关联到一个应用程序中的不同解决方案。在本章中我们将学习几个设计模式,例如依赖注入容器和服务定位器。
第8 章,通用JavaScript 的Web 应用程序,探讨了现代JavaScript Web 应用最有趣的功能之一:前、后端代码共享。本章我们将学习通用的JavaScript 基本原则,通过使用React、Webpack和Babel 来构建一个简单的Web 应用程序。
第9 章,高级异步编程技巧,本章展示怎样使用直接可用的解决方案来解决一些常见的编码和设计问题。
第10 章,扩展和架构模式,介绍扩展Node.js 应用的基本技术和模式。
第11 章,消息传递与集成模式,提出了最重要的消息传递模式,介绍如何构建和集成使用ZMQ 和AMQP 的复杂的分布式系统。
你需要为本书准备什么
为了试验代码,需要安装Node.js 第6 版(或更高版本)和npm 3(或更高版本) 。一些例子还要求使用转码器,例如Babel。还需要熟悉命令提示符,了解如何安装npm 包,还要了解怎样运行Node.js 应用。还需要有一个文本编辑器来编写代码和一个现代浏览器进行测试。适合读者本书适合于已经接触过Node.js 并且想在效率、设计质量和可扩展性方面获得提升的开发者。由于本书也包含一些基本概念,因此你只需要通过一些基本例子了解相关技术即可。中级Node.js 的开发者也会从本书有所收获。具备一些软件设计理论背景知识也会有助于理解本书提出的概念。本书假定你有Web 应用开发、JavaScript、Web 服务、数据库和数据结构的相关知识。
约定
在本书中,你会发现许多文本样式,这些样式用于区分不同种类的信息。
下面是一些这些样式的例子和它们表示的含义。
代码块设置如下:const zmq = require(‘zmq’)const sink = zmq.socket(‘pull’);sink.bindSync(“tcp://*:5001”);sink.on(‘message’, buffer => {console.log(`Message from worker: ${buffer.toString()}`);});当希望读者特别注意代码块的特定部分时,以粗体显示该部分:function produce() {//…variationsStream(alphabet, maxLength).on(‘data’, combination => {//…const msg = {searchHash: searchHash, variations: batch};channel.sendToQueue(‘jobs_queue’, new Buffer(JSON.stringify(msg)));//…})//…}任何命令行输入或输出设置如下:node repliernode requestor
新术语和重要词汇会以粗体显示。
评论
还没有评论。