diff options
Diffstat (limited to 'pool.go')
-rwxr-xr-x | pool.go | 97 |
1 files changed, 55 insertions, 42 deletions
@@ -4,49 +4,52 @@ import ( "context" "runtime" "time" + + "github.com/spiral/roadrunner/v2/util" ) +// PoolEvent triggered by pool on different events. Pool as also trigger WorkerEvent in case of log. +type PoolEvent struct { + // Event type, see below. + Event int64 + + // Payload depends on event type, typically it's worker or error. + Payload interface{} +} + const ( // EventWorkerConstruct thrown when new worker is spawned. - EventWorkerConstruct = iota + 100 + EventWorkerConstruct = iota + 7800 // EventWorkerDestruct thrown after worker destruction. EventWorkerDestruct - // EventWorkerKill thrown after worker is being forcefully killed. - EventWorkerKill - - // EventWorkerError thrown any worker related even happen (passed with WorkerError) - EventWorkerEvent - - // EventWorkerDead thrown when worker stops worker for any reason. - EventWorkerDead - - // EventPoolError caused on pool wide errors + // EventPoolError caused on pool wide errors. EventPoolError -) -const ( - // EventMaxMemory caused when worker consumes more memory than allowed. - EventMaxMemory = iota + 8000 + // EventSupervisorError triggered when supervisor can not complete work. + EventSupervisorError - // EventTTL thrown when worker is removed due TTL being reached. Context is rr.WorkerError + // todo: EventMaxMemory caused when worker consumes more memory than allowed. + EventMaxMemory + + // todo: EventTTL thrown when worker is removed due TTL being reached. Context is rr.WorkerError EventTTL - // EventIdleTTL triggered when worker spends too much time at rest. + // todo: EventIdleTTL triggered when worker spends too much time at rest. EventIdleTTL - // EventExecTTL triggered when worker spends too much time doing the task (max_execution_time). + // todo: EventExecTTL triggered when worker spends too much time doing the task (max_execution_time). EventExecTTL ) // Pool managed set of inner worker processes. type Pool interface { - // ATTENTION, YOU SHOULD CONSUME EVENTS, OTHERWISE POOL WILL BLOCK - Events() chan PoolEvent + // AddListener connects event listener to the pool. + AddListener(listener util.EventListener) - // Exec one task with given payload and context, returns result or error. - ExecWithContext(ctx context.Context, rqs Payload) (Payload, error) + // GetConfig returns pool configuration. + GetConfig() Config // Exec Exec(rqs Payload) (Payload, error) @@ -54,18 +57,14 @@ type Pool interface { // Workers returns worker list associated with the pool. Workers() (workers []WorkerBase) + // Remove worker from the pool. RemoveWorker(ctx context.Context, worker WorkerBase) error - Config() Config - // Destroy all underlying stack (but let them to complete the task). Destroy(ctx context.Context) } -// todo: merge with pool options - -// Config defines basic behaviour of worker creation and handling process. -// +// Configures the pool behaviour. type Config struct { // NumWorkers defines how many sub-processes can be run at once. This value // might be doubled by Swapper while hot-swap. Defaults to number of CPU cores. @@ -84,20 +83,8 @@ type Config struct { // properly destroy, if timeout reached worker will be killed. Defaults to 60s. DestroyTimeout time.Duration - // TTL defines maximum time worker is allowed to live. - TTL int64 - - // IdleTTL defines maximum duration worker can spend in idle mode. Disabled when 0. - IdleTTL int64 - - // ExecTTL defines maximum lifetime per job. - ExecTTL time.Duration - - // MaxPoolMemory defines maximum amount of memory allowed for worker. In megabytes. - MaxPoolMemory uint64 - - // MaxWorkerMemory limits memory per worker. - MaxWorkerMemory uint64 + // Supervision config to limit worker and pool memory usage. + Supervisor SupervisorConfig } // InitDefaults enables default config values. @@ -113,4 +100,30 @@ func (cfg *Config) InitDefaults() { if cfg.DestroyTimeout == 0 { cfg.DestroyTimeout = time.Minute } + + cfg.Supervisor.InitDefaults() +} + +type SupervisorConfig struct { + // WatchTick defines how often to check the state of worker. + WatchTick time.Duration + + // TTL defines maximum time worker is allowed to live. + TTL int64 + + // IdleTTL defines maximum duration worker can spend in idle mode. Disabled when 0. + IdleTTL int64 + + // ExecTTL defines maximum lifetime per job. + ExecTTL time.Duration + + // MaxWorkerMemory limits memory per worker. + MaxWorkerMemory uint64 +} + +// InitDefaults enables default config values. +func (cfg *SupervisorConfig) InitDefaults() { + if cfg.WatchTick == 0 { + cfg.WatchTick = time.Second + } } |