nodejs并发 eventproxy
时间:2019-02-21
本文章向大家介绍nodejs并发 eventproxy,主要包括nodejs并发 eventproxy使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
eventproxy处理并发事件
eventproxy属于eventemitter,有和其相似的方法
addListener on once 注册事件
emit 触发事件
removeListener(‘evnt’,eventHandle) removeAllListeners([…events]) 清除事件
eventproxy常用方法:
1、需要ev1、ev2、ev3并发执行之后执行callback:
.all(‘ev1’,‘ev2’,‘ev3’,(ev1,ev2,ev3)=>{
callback(arguments);
}) 注册并发执行的’ev1’,‘ev2’,‘ev3’…等事件
.emit(‘ev1’,ev1) … 触发事件并返回数据
2、有一组urls:[url1,url2,url3…]需要并发执行
.after(‘topic’,urls.length,([])=>{}); 注册并发执行urls.length次的事件’topic’
const Eventproxy = require('eventproxy');
var request = require('request');
const urls = ['http://baidu.com?id=123r42', 'http://baidu.com?id=123r43', 'http://baidu.com?id=123r44'];
const most = urls.length;//并发数
const eq = new Eventproxy();
const data = [];
eq.after('topics', most, (topic) => {//topic [[url0,data0],[url1,data1]]
topic.map((item) => {
data.push({
url: item[0],
resdata: item[1]
})
})
console.log(data);
return data;
});
//添加error handler
eq.fail((err) => {
console.log(err);
});
urls.map((item) => [
request(item, function (error, response, body) {
if (!error && response.statusCode == 200) {
eq.emit('topics', [item, body]);//触发‘topic’事件
}
})
]);
并发执行返回的数据
- CVPR2018: Unsupervised Cross-dataset Person Re-identification by Transfer Learning of Spatio-tempora
- 一个数据包消灭一台服务器的DNS漏洞
- java文件基本操作与实例
- 如何在Azkaban中安装HDFS插件以及与CDH集成
- CVE-2017-5123 漏洞利用全攻略
- sqlmap被ban了ip怎么办
- 毫秒级检测!你见过带GPU的树莓派吗?
- 达观数据对AngularJS技术的思考与实践
- hadoop配置文件
- 推荐一款src自动化扫描和收集的工具
- 蓝桥杯:兰顿蚂蚁
- 蓝桥杯:矩阵翻硬币
- PTA 字符串关键字的散列映射(25 分)
- struts2中action如何获取jsp页面参数
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 巧用ingest pipeline实现Elasticsearch索引的重定向
- leetcode之错误的集合
- vue-element怎么给select下拉框赋值?
- vue 怎么将Checkbox 多选框选中的值提交
- Chrome的小恐龙游戏自动躲避障碍物
- Three.js教程(5):光源
- Three.js教程(6):几何体
- Three.js教程(7):材质
- Keep APP技术研究
- Canvas系列(15):实战-小球拖拽
- Canvas系列(16):实战-小球与斜面碰撞
- Three.js教程(3):场景
- Three.js教程(4):相机
- 使用GithubActions自动部署应用到自己的服务器(ECS)
- Nuxt项目给script标签添加crossorigin属性