Lesson-2 初识Nodejs(2)

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

你可能感兴趣的:(Lesson-2 初识Nodejs(2))