详解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 npm包管理的配置方法及常用命令介绍
Jun 05 NodeJs
轻松创建nodejs服务器(3):代码模块化
Dec 18 NodeJs
浅析nodejs实现Websocket的数据接收与发送
Nov 19 NodeJs
Nodejs中session的简单使用及通过session实现身份验证的方法
Feb 04 NodeJs
NodeJS遍历文件生产文件列表功能示例
Jan 22 NodeJs
Nodejs多站点切换Htpps协议详解及简单实例
Feb 23 NodeJs
nodejs中模块定义实例详解
Mar 18 NodeJs
nodejs multer实现文件上传与下载
May 10 NodeJs
浅析 NodeJs 的几种文件路径
Jun 07 NodeJs
Nodejs 复制文件/文件夹的方法
Aug 24 NodeJs
nodejs实现大文件(在线视频)的读取
Oct 16 NodeJs
Nodejs连接mysql并实现增、删、改、查操作的方法详解
Jan 04 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微信支付之APP支付方法
2015/03/04 PHP
laravel框架实现后台登录、退出功能示例
2019/10/31 PHP
传智播客学习之java 反射
2009/11/22 Javascript
JQuery自定义事件的应用 JQuery最佳实践
2010/08/01 Javascript
jQuery jqgrid 对含特殊字符json 数据的 Java 处理方法
2011/01/01 Javascript
JavaScript 32位整型无符号操作示例
2013/12/08 Javascript
Google官方支持的NodeJS访问API,提供后台登录授权
2014/07/29 NodeJs
使用Node.js为其他程序编写扩展的基本方法
2015/06/23 Javascript
AngularJS辅助库browserTrigger用法示例
2016/11/03 Javascript
javascript深拷贝的原理与实现方法分析
2017/04/10 Javascript
自定义vue全局组件use使用、vuex的使用详解
2017/06/14 Javascript
详解vue.js之props传递参数
2017/12/12 Javascript
Angular实现的table表格排序功能完整示例
2017/12/22 Javascript
nodejs连接mysql数据库及基本知识点详解
2018/03/20 NodeJs
vue动态删除从数据库倒入列表的某一条方法
2018/09/29 Javascript
vue.js 打包时出现空白页和路径错误问题及解决方法
2019/06/26 Javascript
python切换hosts文件代码示例
2013/12/31 Python
Python批量修改文件后缀的方法
2014/01/26 Python
python文件写入实例分析
2015/04/08 Python
使用Python求解最大公约数的实现方法
2015/08/20 Python
python 与GO中操作slice,list的方式实例代码
2017/03/20 Python
python万年历实现代码 含运行结果
2017/05/20 Python
Python中xml和json格式相互转换操作示例
2018/12/05 Python
python按修改时间顺序排列文件的实例代码
2019/07/25 Python
python获取指定日期范围内的每一天,每个月,每季度的方法
2019/08/08 Python
python中对_init_的理解及实例解析
2019/10/11 Python
python 有效的括号的实现代码示例
2019/11/11 Python
wxpython+pymysql实现用户登陆功能
2019/11/19 Python
利用python 下载bilibili视频
2020/11/13 Python
Html5 webRTC简单实现视频调用的示例代码
2020/09/23 HTML / CSS
波兰家具和室内装饰品购物网站:Vivre
2018/04/10 全球购物
Maxpeedingrods美国:高性能汽车零件
2020/02/14 全球购物
个人剖析材料范文
2014/09/30 职场文书
共产党员批评与自我批评
2014/10/15 职场文书
Java Dubbo框架知识点梳理
2021/06/26 Java/Android
Python pyecharts绘制条形图详解
2022/04/02 Python