mirror of
https://github.com/nodejs/node.git
synced 2025-08-15 13:48:44 +02:00
async_hooks: add sync enterWith to ALS
This allows transitioning the entire following sync and async execution sub-tree to the given async storage context. With this one can be sure the context binding will remain for any following sync activity and all descending async execution whereas the `run*(...)` methods must wrap everything that is intended to exist within the context. This is helpful for scenarios such as prepending a `'connection'` event to an http server which binds everything that occurs within each request to the given context. This is helpful for APMs to minimize the need for patching and especially adding closures. PR-URL: https://github.com/nodejs/node/pull/31945 Reviewed-By: Vladimir de Turckheim <vlad2t@hotmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
This commit is contained in:
parent
2a7d66200b
commit
d368dcc63a
3 changed files with 65 additions and 3 deletions
|
@ -245,7 +245,7 @@ class AsyncLocalStorage {
|
|||
}
|
||||
}
|
||||
|
||||
_enter(store) {
|
||||
enterWith(store) {
|
||||
if (!this.enabled) {
|
||||
this.enabled = true;
|
||||
storageList.push(this);
|
||||
|
@ -258,7 +258,7 @@ class AsyncLocalStorage {
|
|||
runSyncAndReturn(store, callback, ...args) {
|
||||
const resource = executionAsyncResource();
|
||||
const outerStore = resource[this.kResourceStore];
|
||||
this._enter(store);
|
||||
this.enterWith(store);
|
||||
try {
|
||||
return callback(...args);
|
||||
} finally {
|
||||
|
@ -288,7 +288,7 @@ class AsyncLocalStorage {
|
|||
run(store, callback, ...args) {
|
||||
const resource = executionAsyncResource();
|
||||
const outerStore = resource[this.kResourceStore];
|
||||
this._enter(store);
|
||||
this.enterWith(store);
|
||||
process.nextTick(callback, ...args);
|
||||
resource[this.kResourceStore] = outerStore;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue