repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
build(deps): bump poolifier
[poolifier.git]
/
src
/
pools
/
abstract-pool.ts
diff --git
a/src/pools/abstract-pool.ts
b/src/pools/abstract-pool.ts
index a0fc76c371584d3e69855fe732d720db482cc0bf..645a31e1b1edeed626d47d5d31a2bab23dbeaa83 100644
(file)
--- a/
src/pools/abstract-pool.ts
+++ b/
src/pools/abstract-pool.ts
@@
-622,7
+622,7
@@
export abstract class AbstractPool<
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].addEventListener(
'emptyqueue',
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].addEventListener(
'emptyqueue',
- this.handleEmptyQueueEvent
+ this.handleEmptyQueueEvent
as EventListener
)
}
}
)
}
}
@@
-631,7
+631,7
@@
export abstract class AbstractPool<
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].removeEventListener(
'emptyqueue',
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].removeEventListener(
'emptyqueue',
- this.handleEmptyQueueEvent
+ this.handleEmptyQueueEvent
as EventListener
)
}
}
)
}
}
@@
-640,7
+640,7
@@
export abstract class AbstractPool<
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].addEventListener(
'backpressure',
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].addEventListener(
'backpressure',
- this.handleBackPressureEvent
+ this.handleBackPressureEvent
as EventListener
)
}
}
)
}
}
@@
-649,7
+649,7
@@
export abstract class AbstractPool<
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].removeEventListener(
'backpressure',
for (const [workerNodeKey] of this.workerNodes.entries()) {
this.workerNodes[workerNodeKey].removeEventListener(
'backpressure',
- this.handleBackPressureEvent
+ this.handleBackPressureEvent
as EventListener
)
}
}
)
}
}
@@
-1276,6
+1276,8
@@
export abstract class AbstractPool<
workerUsage.tasks.executing === 0 &&
this.tasksQueueSize(localWorkerNodeKey) === 0)))
) {
workerUsage.tasks.executing === 0 &&
this.tasksQueueSize(localWorkerNodeKey) === 0)))
) {
+ // Flag the worker node as not ready immediately
+ this.flagWorkerNodeAsNotReady(localWorkerNodeKey)
this.destroyWorkerNode(localWorkerNodeKey).catch(error => {
this.emitter?.emit(PoolEvents.error, error)
})
this.destroyWorkerNode(localWorkerNodeKey).catch(error => {
this.emitter?.emit(PoolEvents.error, error)
})
@@
-1366,13
+1368,13
@@
export abstract class AbstractPool<
if (this.opts.tasksQueueOptions?.taskStealing === true) {
this.workerNodes[workerNodeKey].addEventListener(
'emptyqueue',
if (this.opts.tasksQueueOptions?.taskStealing === true) {
this.workerNodes[workerNodeKey].addEventListener(
'emptyqueue',
- this.handleEmptyQueueEvent
+ this.handleEmptyQueueEvent
as EventListener
)
}
if (this.opts.tasksQueueOptions?.tasksStealingOnBackPressure === true) {
this.workerNodes[workerNodeKey].addEventListener(
'backpressure',
)
}
if (this.opts.tasksQueueOptions?.tasksStealingOnBackPressure === true) {
this.workerNodes[workerNodeKey].addEventListener(
'backpressure',
- this.handleBackPressureEvent
+ this.handleBackPressureEvent
as EventListener
)
}
}
)
}
}
@@
-1601,7
+1603,7
@@
export abstract class AbstractPool<
* @returns The worker information.
*/
protected getWorkerInfo (workerNodeKey: number): WorkerInfo {
* @returns The worker information.
*/
protected getWorkerInfo (workerNodeKey: number): WorkerInfo {
- return this.workerNodes[workerNodeKey].info
+ return this.workerNodes[workerNodeKey]
?
.info
}
/**
}
/**
@@
-1641,6
+1643,10
@@
export abstract class AbstractPool<
}
}
}
}
+ protected flagWorkerNodeAsNotReady (workerNodeKey: number): void {
+ this.getWorkerInfo(workerNodeKey).ready = false
+ }
+
/** @inheritDoc */
public hasWorkerNodeBackPressure (workerNodeKey: number): boolean {
return (
/** @inheritDoc */
public hasWorkerNodeBackPressure (workerNodeKey: number): boolean {
return (