DNS
这是一个与DNS相关的库
这个库有两种方式
第一种是使用系统的底层解析 不需要网络通讯
var dns = require('dns');
dns.lookup('www.google.com', function onLookup(err, addresses, family) {
console.log('addresses:', addresses);
});
第二种是像DNS去获取信息 Node提供了大量的便利方法和带有可选项的方法, 这里可选项很多 IPV4 IPV6 CNAME ......
而且模块还提供了反向解析ip的方法 dns.reverse(ip, callback)
Domain
域 不太理解 字面上的解释是把不同的IO操作看作是同一个组内的操作
文档上第一个例子就是域能够统一处理错误
var d = require('domain').create();
d.on('error', function(er) {
// The error won't crash the process, but what it does is worse!
// Though we've prevented abrupt process restarting, we are leaking
// resources like crazy if this ever happens.
// This is no better than process.on('uncaughtException')!
console.log('error, but oh well', er.message);
});
d.run(function() {
require('http').createServer(function(req, res) {
handleRequest(req, res);
}).listen(PORT);
});
域有两种与事件的绑定方式, 第一种为隐士绑定 是如果域正在使用中 那么域所有新的分发的对象都会隐士绑定, 第二种就是需要我们手动调用的显示绑定
Class: Domain
域是EventEmitter 的子类
与能够添加或者删除事件分发器和Timer
domain的作用是解决了以前异步无法try catch的纠结
再出现domain之前,我们可以使用process.on(‘uncaughtException’)来捕获全局异常,但是我们其实并不能及时给出友好的回应
有一种特殊的情况是domain也无法捕获错误的 ,就是 及时错误是在domain的上下文中抛出的 但是抛出错误的事件并不是在上下文中生成 也没有绑定到domain中的时候 是无法捕获异常的】
Child Process
子进程模块
不能直接调用 ChildProcess 类,使用 spawn(), exec(), execFile(), 或 fork()方法来创建子进程
spawn 是最原始的参数 其他三种都是spawn的某种程度的封装 他们接受的参数不同
Class: ChildProcess
ChildProcess 是 EventEmitter 的子类
子进程有三个十分重要的流对象stdin, stdout, and stderr 其实他们都存在stdio的数组中,下标依次为0~2
子进程的工作原理的就是让子进程执行一系列的命令 然后在相应相应的事件
当然你同时也可以给子进程的几个流对象添加监听
Cluster
集群 集群的优点是可以简单地创建和管理子进程 从而更好的利用多核CPU资源
依我浅显的理解就是 集群就是对子进程的封装 首先封装了选取子进程的方式, 我们可以设置相应的选取策略,其次就是对每个子进程任务进行封装,封装个一个个worker