项目作者: gms1

项目描述 :
a continuation local storage / asynchronous execution context for node.js via async_hooks
高级语言: TypeScript
项目地址: git://github.com/gms1/node-async-context.git
创建时间: 2016-12-22T22:46:52Z
项目社区:https://github.com/gms1/node-async-context

开源协议:MIT License

下载


node-async-context (asyncctx)

THIS PROJECT HAS BEEN MOVED!

THE NEW LOCATION IS HERE: asyncctx

npm version
Build Workflow
Coverage Status
Dependency Status
Known Vulnerabilities

NPM

This module allows you to create an asynchronous execution context for JavaScript or TypeScript

NOTE: This module is based on async_hooks an experimental built-in node.js module introduced in v8.0.0

Deprecation

NOTE: This module is now deprecated in favour of AsyncLocalStorage
which is available for nodejs >= 12

quick start using AsyncLocalStorage

  1. class ContinuationLocalStorage<T> extends AsyncLocalStorage<T> {
  2. public getContext(): T | undefined {
  3. return this.getStore();
  4. }
  5. public setContext(value: T): T {
  6. this.enterWith(value);
  7. return value;
  8. }
  9. }

Introduction

To give you an idea of how asyncctx is supposed to be used:

  1. import { ContinuationLocalStorage } from 'asyncctx';
  2. class MyLocalStorage {
  3. value: number;
  4. }
  5. let cls = new ContinuationLocalStorage<MyLocalStorage>();
  6. cls.setRootContext({ value: 1});
  7. process.nextTick(() => {
  8. let curr1 = cls.getContext(); // value is 1
  9. cls.setContext({ value: 2}); // value should be 2 in the current execution context and below
  10. process.nextTick(() => {
  11. let curr2 = cls.getContext(); // value is 2
  12. cls.setContext({ value: 3}); // value should be 3 in the current execution context and below
  13. process.nextTick(() => {
  14. let curr3 = cls.getContext(); // value is 3
  15. });
  16. });
  17. process.nextTick(() => {
  18. let curr4 = cls.getContext(); // value is 2
  19. });
  20. });

License

node-async-context (asyncctx) is licensed under the MIT License:
LICENSE

Release Notes

Release Notes
2.0.18-19 deprecated in favour of AsyncLocalStorage
2.0.12-17 maintenance release, nodejs 14 support
2.0.11 #54: fixed memory leak for chaining asynchronous calls infinitely; thanks to Reko Tiira
2.0.10 maintenance release
2.0.9 node 13 supported
2.0.3-8 maintenance release
2.0.2 #47: fixed loosing context for unknown resource types; thanks to Pasi Tuominen
2.0.1 maintenance release
2.0.0 targeting es2015; dropped support for nodejs < v8
please use asyncctx@<2.0 for nodejs v4 - v11 support
1.1.0 fixed support for nodes < v8
1.0.5-10 maintenance release
1.0.4 node 10 supported
1.0.3 node 9 supported
1.0.2 maintenance release
1.0.1 added support for older nodejs versions (4,6,7) using internal copy of async-hook@1.7.1
1.0.0 is now based on ‘async_hooks’ (a built-in nodejs v8.0 module)
0.0.6 maintenance releases
0.0.5 async-hook 1.7.1
0.0.1-4 initial version