详解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服务器(2):nodejs服务器的构成分析
Dec 18 NodeJs
Nodejs实现批量下载妹纸图
May 28 NodeJs
nodejs导出excel的方法
Jun 30 NodeJs
Nodejs初级阶段之express
Nov 23 NodeJs
nodejs制作爬虫实现批量下载图片
May 19 NodeJs
nodejs发送http请求时遇到404长时间未响应的解决方法
Dec 10 NodeJs
详解Nodejs mongoose
Jun 10 NodeJs
nodejs之koa2请求示例(GET,POST)
Aug 07 NodeJs
nodejs基础之多进程实例详解
Dec 27 NodeJs
Nodejs实现用户注册功能
Apr 14 NodeJs
如何利用nodejs实现命令行游戏
Nov 24 NodeJs
在nodejs中创建child process的方法
Jan 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 IE中下载附件问题解决方法
2014/01/07 PHP
php str_getcsv把字符串解析为数组的实现方法
2017/04/05 PHP
php集成开发环境详解
2019/09/24 PHP
对xmlHttp对象的理解
2011/01/17 Javascript
异步javascript的原理和实现技巧介绍
2012/11/08 Javascript
利用JQuery和JS实现奇偶行背景颜色自定义效果
2012/11/19 Javascript
js中 关于undefined和null的区别介绍
2013/04/16 Javascript
javascript实现修改微信分享的标题内容等
2014/12/11 Javascript
完美兼容多浏览器的js判断图片路径代码汇总
2015/04/17 Javascript
Javascript函数式编程简单介绍
2015/10/11 Javascript
浅谈javascript的call()、apply()、bind()的用法
2016/02/21 Javascript
jQuery实现背景弹性滚动的导航效果
2016/06/01 Javascript
jQuery实现键盘回车搜索功能
2017/07/25 jQuery
nodejs之get/post请求的几种方式小结
2017/07/26 NodeJs
详解swipe使用及竖屏页面滚动方法
2018/06/28 Javascript
Javascript迭代、递推、穷举、递归常用算法实例讲解
2019/02/01 Javascript
JS FormData对象使用方法实例详解
2020/02/12 Javascript
[01:23:35]Ti4主赛事胜者组 DK vs EG 1
2014/07/19 DOTA
python 七种邮件内容发送方法实例
2014/04/22 Python
在Python中构建增广矩阵的实现方法
2019/07/01 Python
Pytorch卷积层手动初始化权值的实例
2019/08/17 Python
python 实现任务管理清单案例
2020/04/25 Python
学习python需要有编程基础吗
2020/06/02 Python
从零开始的TensorFlow+VScode开发环境搭建的步骤(图文)
2020/08/31 Python
html5 视频播放解决方案
2016/11/06 HTML / CSS
倩碧澳大利亚官网:Clinique澳大利亚
2019/07/22 全球购物
介绍一下木马病毒的种类
2015/07/26 面试题
《三顾茅庐》教学反思
2014/04/10 职场文书
2014医学院领导班子对照检查材料思想汇报
2014/09/19 职场文书
基层党员四风问题自我剖析材料
2014/09/29 职场文书
少儿励志名言(80句)
2019/08/14 职场文书
Nginx使用X-Accel-Redirect实现静态文件下载的统计、鉴权、防盗链、限速等
2021/04/04 Servers
zabbix agent2 监控oracle数据库的方法
2021/05/13 Oracle
Redis Cluster集群动态扩容的实现
2021/07/15 Redis
Java实现添加条码或二维码到Word文档
2022/06/01 Java/Android
win10电脑关机快捷键是哪个 win10快速关机的几种方法
2022/08/14 数码科技