nodejs异步流程控制

Posted 月疯

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nodejs异步流程控制相关的知识,希望对你有一定的参考价值。

场景:

1、图片上传服务器

2、图片写入磁盘

3、图片写入数据库

在nodejs里面这三种方式都是异步操作,不想java其他语言同步进行,这就需要对异步流程进行控制,保证1,2,3逐步进行。有可能1还没完成,2和3可能就开始了,所以需要控制流程。


异步流程控制对象async
1、串行无关联:async.series(1,2,3按照顺序执行)
2、并行无关联:async.parallel(1,2,3一起跑)
3、串行有关联:waterfall(瀑布流关系,1完成传给2,2完成传给3)
4、parallelLimit:parallelLimit函数和parallel类似,但是它多了一个参数limit。(同一时间只能并行2个或者三个任务)
limit参数限制任务只能同时并发一定数量,而不是无限制并发

 

 先要进行安装:npm install async --save-dev

 

 串行无关联:async.series测试:

let async=require('async');
function exec(){
    async.series({
        one:function(done){
            ii=0;
            setInterval(function(){
                console.log('aaa='+new Date());
                ii++;
                if(ii==3){
                    clearInterval(this);
                    done(null,'one完毕');
                }
            },1000);
        },
        two:function(done){
            jj=0;
            setInterval(function(){
                console.log('bbb='+new Date());
                jj++;
                if(jj==3){
                    clearInterval(this);
                    done(null,'two完毕');
                }
            },1000);

        }
    },function(err,rs){
        console.log(err);
        console.log(rs);
    })
}
exec();
console.log('主进程执行完毕');

 并行无关联:async.parallel测试:

let async=require('async');
function exec(){
    async.parallel({
        one:function(done){
            ii=0;
            setInterval(function(){
                console.log('aaa='+new Date());
                ii++;
                if(ii==3){
                    clearInterval(this);
                    done(null,'one完毕');
                }
            },1000);
        },
        two:function(done){
            jj=0;
            setInterval(function(){
                console.log('bbb='+new Date());
                jj++;
                if(jj==3){
                    clearInterval(this);
                    done(null,'two完毕');
                }
            },1000);

        }
    },function(err,rs){
        console.log(err);
        console.log(rs);
    })
}
exec();
console.log('主进程执行完毕');

 串行有关联:waterfall测试:

let async=require('async');
function exec(){
    //第一个的回调是第二个的参数
    async.waterfall([
        function(done){
            ii=0;
            setInterval(function(){
                console.log('aaa='+new Date());
                ii++;
                if(ii==3){
                    clearInterval(this);
                    done(null,'one完毕');
                }
            },1000);
        },
        function(preValue,done){
            jj=0;
            setInterval(function(){
                console.log('bbb='+new Date());
                jj++;
                if(jj==3){
                    clearInterval(this);
                    done(null,preValue+'two完毕');
                }
            },1000);

        }
    ],function(err,rs){
        console.log(err);
        console.log(rs);
    })
}
exec();
console.log('主进程执行完毕');

 

 

以上是关于nodejs异步流程控制的主要内容,如果未能解决你的问题,请参考以下文章

NodeJs异步的执行过程

nodejs异步调用async

nodejs中的异步流程序控制nsync

如何在 NodeJS 中控制应用程序的流动

nodejs爬虫使用async控制并发写一个小说爬虫

NodeJs - 控制器内的异步/等待[重复]