zoukankan      html  css  js  c++  java
  • NodeJs 异步队列(AsyncQueue)

    原文地址

    NodeJs 程序并没有锁概念, 可能是单线程程序的缘故吧. 但是存在异步回调, 也就造成并发执行统一代码的可能性, 当然这里并发不是真正意义上的并发. 是同一线程在不同时间点执行统一代码. 事故类似代码如下:

    // 阻塞函数
    const sleep = async (ms = 0) => {
    	return new Promise((resolve, reject) => {
    		return setTimeout(resolve(true), ms);
    	})
    }
    
    let total = 0;
    const demoFunc = async () => {
        let count = total;
        await sleep(2000)
        total = count + 1;
    }
    
    demoFunc();
    demoFunc();
    sleep(4000);
    console.log(total); // 输出 1
    

    示例是一个很简单的自增行为, 很多人可能会说直接在demoFunc()前加 await 不是就是期望结果了, 然后事实可能是真的无法直接这样做, demoFunc 函数代表其实是一个web请求的处理. total 是数据读存(db 或 file).
    我期望的结果是 2, 实际结果却为 1. 具体情况不同可能有不同解决方案, 本文提供一种异步队列机制去顺序执行需要互斥的的代码.

    最简单的互斥执行

    只用使用 Promise 链执行顺序执行互斥代码.

    let queue = Promise.resolve(true);
    
    const queue_exec = async (fn) => {
        queue = queue.then(() => {
            try {
                return Promise.resolve(fn());
            } catch(err) {
                return Promise.reject(err);
            }
        });
        return queue;
    }
    
    // 上述示例换成如下调用即可
    queue_exec(demoFunc);  // 在实际的请求中可以用 await queue_exec(demoFunc) 或去执行结果.
    

    完善包装成 NPM 包

    上述列表实现过于简单, 可以做很多优化, 如队列大小控制, 互斥代码执行超时, 执行优先级等... 既然实现原理已表明, 锦上添花的功能就不在细化描述, 具体实现参考: AsyncQueue.

    假定代码已经编写完善, 目录为 AsyncQueue. 下面记录发布 NPM 包步骤:

    1. cd AsyncQueue # 进入代码目录
    2. npm init # npm 初始化 进入交互模式, 可以一路按回车, 最终生成 package.json 文件
    3. npm login # 登录 NPM 官网, 交互输入 npmjs.com 网站的用户名密码
    4. 编辑 package.json 修改相关字段
      • name 包名, 不支持大写, 而且极易与存在的包名冲突, 可以通过 @用户名/包名 格式做为包名, 避免冲突, 缺点就是包名很长.
      • main 入口文件名, 指定 require(包名) 需要加载到文件名
      • version 包版本
      • 其它字段按需修改即可
    5. 编写 README.md 文件, 如包安装 npm install 包名 --save 包介绍, 用法等, 可选.
    6. npm publish --access=public # 发布包, --access=public 显示发布公开包
    7. 变更完成, 更新 package.json 中 version 字段, 重新发布 npm publish --access=public 即可.
  • 相关阅读:
    SQL中top使用方法
    event.keyCode 事件属性
    A Novel Multi-label Classification Based on PCA and ML-KNN
    Android 浏览器开发WebView setBlockNetworkImage本末
    ASIHTTPRequest 对GET POST 请求简包
    九度OJ 1177 查找 (模拟)
    【Java GUI】Java GUI基金会
    iOS开展-clang: error: unknown argument: '-websockets'解决方案
    java学习笔记2015-6-6
    oracle 选择最频繁出现之前,5文章数据
  • 原文地址:https://www.cnblogs.com/--xiaoyao--/p/11612855.html
Copyright © 2011-2022 走看看