详解nodejs中的process进程


Posted in NodeJs onMarch 19, 2017

虽然node对操作系统做了很多抽象的工作,但是你还是可以直接和他交互,比如和系统中已经存在的进程进行交互,创建工作子进程。node是一个用于事件循环的线程,但是你可以在这个事件循环之外创建其他的进程(线程)参与工作。

进程模块

process模块允许你获得或者修改当前node进程的设置,不想其他的模块,process是一个全局进程(node主进程),你可以直接通过process变量直接访问它。

process实现了EventEmitter接口,exit方法会在当进程退出的时候执行。因为进程退出之后将不再执行事件循环,所有只有那些没有回调函数的代码才会被执行。在下面例子中,setTimeout里面的语句是没有办法执行到的。

process.on('exit', function () {
setTimeout(function () {


console.log('This will not run');

}, 100);

console.log('Bye.');
});

在你接触node之后,你就会发现那些影响了主事件循环的异常会把整个node进程宕掉的。这会是相当严重的问题,所以process提供了另外一个有用的事件uncaughtException来解决这个问题,他会把异常抓取出来供你处理。

process.on('uncaughtException', function (err) {
console.log('Caught exception: ' + err);
});
setTimeout(function () {

console.log('This will still run.');
}, 500);
// Intentionally cause an exception, but don't catch it.
nonexistentFunc();
console.log('This will not run.');

 

我们来看上面的例子,我们注册了uncaughtException事件来捕捉系统异常。执行到nonexistentFunc()时,因为该函数没有定义所以会抛出异常。因为javascript是解释性的语言,nonexistentFunc()方法上面的语句不会被影响到,他下面的语句不会被执行。所以他的执行结果如下:

Caught exception: ReferenceError: nonexistentFunc is not defined

This will still run.

我们再看一个例子。

var http = require('http');
var server = http.createServer(function(req,res) {
res.writeHead(200, {});

res.end('response');

badLoggingCall('sent response');

console.log('sent response');
});
process.on('uncaughtException', function(e) {

console.log(e);
});
server.listen(8080);

 

在这里例子中我们创建了一个web服务器,当处理完请求之后,我们会执行badLoggingCall()方法。因为这个方法不存在,所以会有异常抛出。但是我们注册的uncaughtException事件会对异常做出处理,这样服务器不会受到影响得以继续运行。我们会在服务器端记录错误日志。

[ReferenceError: badLoggingCall is not defined] 

 

与当前进程交互

node提供了一些process的属性,如下:

process.version:包含当前node实例的版本号;

process.installPrefix:包含安装路径;

process.platform:列举node运行的操作系统的环境,只会显示内核相关的信息,如:linux2, darwin,而不是“Redhat ES3” ,“Windows 7”,“OSX 10.7”等;

process.uptime():包含当前进程运行的时长(秒);

process.getgid(), process.setgid():获取或者设置group id;

process.getuid(), process.setuid():获取或者设计user id;

process.pid:获取进程id;

process.title:设置进程名称;

process.execPath:当前node进程的执行路径,如:/usr/local/bin/node;

process.cwd():当前工作目录;

process.memoryUsage():node进程内存的使用情况,rss代表ram的使用情况,vsize代表总内存的使用大小,包括ram和swap;

process.heapTotal,process.heapUsed:分别代表v8引擎内存分配和正在使用的大小。

 

事件循环和ticker

node中提供了process.nextTick()方法,允许你访问事件循环和延时那你的工作。他有点类似于setTimeout(),他会在下次tick的时候执行,而且每隔一段事件就会执行一次。我们这里有个例子:

var http = require('http');
var s = http.createServer(function(req, res) {
res.writeHead(200, {});

res.end('foo');

console.log('http response');

process.nextTick(function(){console.log('tick')});
});
s.listen(8000);

当请求来的时候,会记录日志‘http response'和‘tick',当没有请求的时候,每隔一段事件会执行事件循环,会输出tick。

此外,nextTick创建的回调函数具有隔离性,他们之间不会相互影响。

process.on('uncaughtException', function(e) {
console.log(e);
});
process.nextTick(function() {

console.log('tick');
});
process.nextTick(function() {

iAmAMistake();

console.log('tock');
});
process.nextTick(function() {

console.log('tick tock');
});
console.log('End of 1st loop');

在这个例子中,首先输出‘End of 1st loop',然后顺序的输出nextTick的回调函数,第一个会正常输出‘tick',第二个是一个故意设置的异常会输出异常信息,不会输出‘tock',因为nextTick回调函数的隔离性,第三个任然会输出‘tick tock'。结果如下:

End of 1st loop
tick
[ReferenceError: iAmAMistake is not defined]
tick tock

子进程

node提供了child_process模块,允许你为主进程创建子进程,这样你就可以使用更多的服务器资源,使用更多的cpu,这些概念在前面的章节有介绍。node提供了child_process. spawn()和child_process. exec()为你实现这一功能,下面我们就单独介绍。

child_process.exec( )

我们来看exec的一个简单例子,他创建了一个子进程,第一个参数是一个shell命令,第二个参数是回调函数,处理返回结果。

var cp = require('child_process');
cp.exec('ls -l', function(e, stdout, stderr) {
if(!e) {


console.log(stdout);


console.log(stderr);

}
});

exec()还可以传options的参数:

var options = { 
 encoding: 'utf8',
 timeout: 0,
 maxBuffer: 200 * 1024,
 killSignal: 'SIGTERM',
 setsid: false,
 cwd: null,
 env: null 
};
var cp = require('child_process');
cp.exec('ls -l', options, function(e, stdout, stderr) {
if(!e) {


console.log(stdout);


console.log(stderr);

}
});

encoding:I/O流的编码格式;

timeout:进程超时时间;

killSignal:当时间或者缓冲区超限时终止进程的信号;

maxBuffer:stdout或stderr可增长的最大值;

setsid:决定在进程中是否创建一个新的会话;

cwd:进程的初始工作目录,为null时表示使用node的当前工作目录;

env:进程的环境变量。

child_process.spawn( )

child_process.spawn( )比child_process.exec( )更加强大和灵活,例子如下:

var cp = require('child_process');
var cat = cp.spawn('cat');
cat.stdout.on('data', function(d) {
console.log(d.toString());
});
cat.on('exit', function() {

console.log('kthxbai');
});
cat.stdin.write('meow');
cat.stdin.end();

以上所述是小编给大家介绍的nodejs中的process进程,希望对大家有所帮助!

NodeJs 相关文章推荐
NodeJS学习笔记之Http模块
Jan 13 NodeJs
Nodejs获取网络数据并生成Excel表格
Mar 31 NodeJs
Nodejs全局安装和本地安装的不同之处
Jul 04 NodeJs
Nodejs中解决cluster模块的多进程如何共享数据问题
Nov 10 NodeJs
详解nodejs微信jssdk后端接口
May 25 NodeJs
nodejs判断文件、文件夹是否存在及删除的方法
Nov 10 NodeJs
Nodejs连接mysql并实现增、删、改、查操作的方法详解
Jan 04 NodeJs
nodejs更改项目端口号的方法
May 13 NodeJs
NodeJS服务器实现gzip压缩的示例代码
Oct 12 NodeJs
nodejs 使用http进行post或get请求的实例(携带cookie)
Jan 03 NodeJs
详解NodeJs项目 CentOs linux服务器线上部署
Sep 16 NodeJs
nodejs中使用archive压缩文件的实现代码
Nov 26 NodeJs
nodejs中使用HTTP分块响应和定时器示例代码
Mar 19 #NodeJs
nodejs中向HTTP响应传送进程的输出
Mar 19 #NodeJs
实例分析nodejs模块xml2js解析xml过程中遇到的坑
Mar 18 #NodeJs
nodejs中模块定义实例详解
Mar 18 #NodeJs
Nodejs基于LRU算法实现的缓存处理操作示例
Mar 17 #NodeJs
用nodeJS搭建本地文件服务器的几种方法小结
Mar 16 #NodeJs
nodejs+express实现文件上传下载管理网站
Mar 15 #NodeJs
You might like
PHP生成短网址方法汇总
2016/07/12 PHP
PHP中Static(静态)关键字功能与用法实例分析
2019/04/05 PHP
thinkphp5.1框架中容器(Container)和门面(Facade)的实现方法分析
2019/08/05 PHP
Thinkphp自定义生成缩略图尺寸的方法
2019/08/05 PHP
调试php程序的简单步骤
2019/10/04 PHP
解决laravel5.4下的group by报错的问题
2019/10/16 PHP
如何在PHP中使用数组
2020/06/09 PHP
js 绑定带参数的事件以及手动触发事件
2010/04/27 Javascript
javascript学习笔记(十三) js闭包介绍(转)
2012/06/20 Javascript
解决jquery插件冲突的问题
2014/01/23 Javascript
jquery实现个人中心导航菜单效果和美观都非常不错
2014/09/02 Javascript
JavaScript使用Math.Min返回两个数中较小数的方法
2015/04/06 Javascript
jquery实现网页的页面平滑滚动效果代码
2015/11/02 Javascript
jquery悬浮提示框完整实例
2016/01/13 Javascript
JS创建对象的写法示例
2016/11/04 Javascript
Angular directive递归实现目录树结构代码实例
2017/05/05 Javascript
JavaScript之json_动力节点Java学院整理
2017/06/29 Javascript
node.js实现的装饰者模式示例
2017/09/06 Javascript
详谈vue+webpack解决css引用图片打包后找不到资源文件的问题
2018/03/06 Javascript
JS实现读取xml内容并输出到div中的方法示例
2018/04/19 Javascript
vue+koa2搭建mock数据环境的详细教程
2020/05/18 Javascript
WebPack工具运行原理及入门教程
2020/12/02 Javascript
基于python的七种经典排序算法(推荐)
2016/12/08 Python
关于python pyqt5安装失败问题的解决方法
2017/08/08 Python
python调用动态链接库的基本过程详解
2019/06/19 Python
Python多进程编程常用方法解析
2020/03/26 Python
Python编写单元测试代码实例
2020/09/10 Python
英国领先的品牌珠宝和配件供应商:Acotis Jewellery
2018/03/07 全球购物
美国在线打印网站:Overnight Prints
2018/10/11 全球购物
马来西亚排名第一的宠物用品店:Pets Wonderland
2020/04/16 全球购物
英语专业毕业生自荐信
2013/10/28 职场文书
孝敬父母的演讲稿
2014/05/14 职场文书
茶楼服务员岗位职责
2015/02/09 职场文书
党校学习个人总结
2015/02/15 职场文书
Java使用httpRequest+Jsoup爬取红蓝球号码
2021/07/02 Java/Android
MyBatis-Plus 批量插入数据的操作方法
2021/09/25 Java/Android