进程管理

1.调用终端命令实现目录目录拷贝

var child_procress = require('child_procress');
var util = require('util');

function copy(source, target, callback){
    child_procress.exec(util.format('cp -r %s/* %s', source, target), callback);
}

copy('a', 'b', function(err){
    // ...
});

2.Process

3.Child Procress

4.Cluster

进程管理有好多东西,但是却不是能写清楚的,具体需要什么怎样运行,其实都是具体情况具体分析,需要的时候查询官方API是个不错的办法。

异步编程

事件机制和异步IO是nodejs的特点。如果不会异步编程,那岂不是说nodejs没什么意思了吗!

1.回调

function heavyCompute(n, callback){
    var count = 0, i, j;
   
    for(i = n; i > 0; --i){
        for(j = n; j > 0; --j){
            count += 1;
        }
    }
   
    callback(count);
   
}

heavyCompute(10000, function(count){
    console.log(count);
});

console.log('hello');

//100000000

//hello

上面的程序是单线程的。

setTimeout(function(){
    console.log('world');
}, 1000);

console.log('hello');

//hello

//world

setTimeout在JS规范外,由运行环境提供的特殊函数创建一个平行进程后立即返回继续执行后续代码,平行线程执行完成后通知回来继续执行回调函数。setinterval,fs.readFile都是这样异步的。

平行线程执行完成工作,通知主线程,主线程如果在忙,则不会立刻执行,而是要等到主线程空闲时才会执行相关操作。

2.代码设计模式

1)函数返回值

//同步

var output = fn1(fn2('input'));

//异步方式

fn2('input', function(output2){
    fn1(output2, function(output1){
       
    });
});

2)遍历数组

//同步
var len = arr.length, 1=0;
for(;i<len;i++){
    arr[i]=sync(arr[i]);
}

//异步

(function next(i, len, callback){
    if(i<len){
        async(arr[i], function(value){
            arr[i]=value;
            next(i+1,len,callback);
        });
    }else{
        callback();
    }
}(0, arr.length, function(){
   
}));

//如果数据数组数据可以并行处理,但是后续代码需要数据数组数据全部处理好的情况下
(function(i, len, count, callback){
    for(;i<len;++i){
        (function(i){
            async(arr[i], function(value){
                arr[i]=value;
                if(++count===len){
                    callback();
                }
            });
        });
    }
}(0, arr.length, 0, function(){
    //init finish
}));

3)异常处理

try-catch

function sync(fn){
    return fn();
}

try{
    sync(null);
}catch(err){
    console.log('err::', err.message);
}
//=>object is not a function

4)域

如果按照上面的方法写,如果是函数多层调用,那代码就太丑了,在上面贴了一个那样的例子,系统提示,代码太丑无法显示,哎,算了,去掉吧,哈哈。因此NodeJS提供domain简化异常处理。用process捕获全局异常。

process.on('uncaughtException', function(err){
    console.log('ERR::', err.message);
});
setTimeout(function(fn){
    fn();
});

function async(request, callback){
    //Do something
    asyncA(request, function(data){
        //Do something
        asyncB(request, function(data){
            //Do something
            asyncC(request, function(data)){
                // Do something
                callback(data);
            }
        });
    });
}

http.createServer(function(request, response){
    var d = domain.create();
   
    d.on('error', function(){
        response.writeHead(500);
        response.end();
    });
   
    d.run(function(){
        async(request, function(data){
            response.writeHead(200);
            response.end(data);
        });
    });
});

【nodejs学习】3.进程管理及异步编程的更多相关文章

  1. Linux学习之进程管理(十九)

    Linux学习之进程管理 进程查看 查看系统中所有进程,使用BSD操作系统的格式 语法:ps aux 选项: a:显示所有前台进程 x:显示所有后台进程 u:显示这个进程是由哪个用户产生的 语法:ps ...

  2. Linux学习之进程管理

    |-进程管理     进程常用命令        |- w查看当前系统信息        |- ps进程查看命令        |- kill终止进程        |- 一个存放内存中的特殊目录/p ...

  3. Linux零起点之进程管理----c语言编程

    进程 (Process)是指操作系统中被加载到内存中的.正在运行的应用程序实例.进程是系统资源分配的基本单元,在其生命周期内会使用系统中的各种资源.进程主要由程序.数据以及进程控制快(PCB)3个部分 ...

  4. Linux系统学习之进程管理

    什么是进程? 进程表示程序的一次执行过程,它是应用程序的运行实例,是一个动态的过程.或者可以更简单地描述为:进程是操作系统当前运行的程序.当一个进程开始运行时,就要启动了这个过程.进程包括动态的执行的 ...

  5. perl学习之进程管理

    系统函数 == 最简单的系统调用  system "date"; # Perl会将 date 命令传递给unix的shell并获取返回值和error信息等   == 带有系统参数的 ...

  6. linux内核学习之进程管理------task_struct结构体

    struct task_struct { volatile long state;    /* -1 unrunnable, 0 runnable, >0 stopped */ struct t ...

  7. nodejs学习以及SSJS漏洞

    0x01 简介 什么是nodejs,it's javascript webserver! JS是脚本语言,脚本语言都需要一个解析器才能运行.对于写在HTML页面里的JS,浏览器充当了解析器的角色.而对 ...

  8. nodejs 异步编程 教程(推荐)

    有异步I/O就需要异步编程.本课程将着重讲解在学习node.js中关于异步编程的一些问题,以及如何应对这些问题,帮助node.js初学者快速入门. 地址 http://www.hubwiz.com/c ...

  9. 深入理解 Python 异步编程(上)

    http://python.jobbole.com/88291/ 前言 很多朋友对异步编程都处于"听说很强大"的认知状态.鲜有在生产项目中使用它.而使用它的同学,则大多数都停留在知 ...

随机推荐

  1. 完整版的strcpy函数

    char *strcpy(char *strDest,const char *strSrc) { assert((strDest!=NULL) && (strSrc!=NULL)); ...

  2. ComboBox相关操作

    取组合框文本示例: 1 void ShowDlgWage::OnCbnSelendokCombo1() { // TODO: 在此添加控件通知处理程序代码 CString str; int i; i ...

  3. Netty 5 传送大文件的方法

    Netty 5 提供了 一个ChunkedWriterHandler 来传送大文件,发送端如下: 添加chunedwriterhandler: ChannelPipeline p = ...; p.a ...

  4. Android的消息处理机制(Looper,Handler,Message)(转)

    Handler Handler的定义: 主要接收子线程发送的数据,并用此数据配合主线程更新UI. 当应用程序启动时,Android首先会开启一个主线程(也就是UI线程),主线程为管理界面中的UI空间进 ...

  5. PHPCMS v9修改栏目或者单页没有权限

    问题: 普通管理员没有权限修改栏目,只有超级管理员才有权限修改,凡是非超级管理员,设置栏目权限后只能添加栏目,不能对栏目进行修改和删除操作,提示您没有权限操作该项这使系统的一个BUG.   一.对于普 ...

  6. WinMain与WndProc以及窗口诞生过程总结

    一.int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR szCmdLine, int nCmdShow) 四个 ...

  7. linux系统ecshop拿shell方法

    Title:linux系统ecshop拿shell方法  --2011-06-08 13:23 最近弄一个站,对ECSHOP拿shell不了解,导致走了很多的弯路. nginx/0.8.54的服务器, ...

  8. shell脚本实例一,移动文件夹中大于2000B的文件到另一个文件夹

    shell脚本能帮我们简化linux下的一些工作,现在有个需求,把TMPA文件夹下大于2000B的文件都移动到TMPB下 #! /bin/bash function movefiles() { ` d ...

  9. javascript 要注意的事项

    记入一些容易出错的地方 function someClass() { this.name = null; 或 undefined } var obj = new someClass(); consol ...

  10. Practice: Process logs with Apache Hadoop

    http://www.ibm.com/developerworks/library/os-log-process-hadoop/ Analyzing Apache logs with Apache P ...