worker

package
v2.18.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 16, 2022 License: MIT Imports: 20 Imported by: 1

Documentation

Index

Constants

View Source
const (
	// StopRequest can be sent by worker to indicate that restart is required.
	// should be in sync with pool
	StopRequest = `{"stop":true}`
)

Variables

This section is empty.

Functions

This section is empty.

Types

type Allocator

type Allocator func() (worker.Worker, error)

Allocator is responsible for worker allocation in the pool

type Options

type Options func(p *Process)

func WithLog

func WithLog(z *zap.Logger) Options

type Process

type Process struct {
	// contains filtered or unexported fields
}

Process - supervised process with api over goridge.Relay.

func InitBaseWorker

func InitBaseWorker(cmd *exec.Cmd, options ...Options) (*Process, error)

InitBaseWorker creates new Process over given exec.cmd.

func (*Process) AttachRelay

func (w *Process) AttachRelay(rl relay.Relay)

AttachRelay attaches relay to the worker

func (*Process) Created

func (w *Process) Created() time.Time

Created returns time worker was created at.

func (*Process) Kill

func (w *Process) Kill() error

Kill kills underlying process, make sure to call Wait() func to gather error log from the stderr. Does not wait for process completion!

func (*Process) Pid

func (w *Process) Pid() int64

Pid returns worker pid.

func (*Process) Relay

func (w *Process) Relay() relay.Relay

Relay returns relay attached to the worker

func (*Process) Start

func (w *Process) Start() error

func (*Process) State

func (w *Process) State() worker.State

State return receive-only Process state object, state can be used to safely access Process status, time when status changed and number of Process executions.

func (*Process) Stop

func (w *Process) Stop() error

Stop sends soft termination command to the Process and waits for process completion.

func (*Process) String

func (w *Process) String() string

String returns Process description. fmt.Stringer interface

func (*Process) Wait

func (w *Process) Wait() error

Wait must be called once for each Process, call will be released once Process is complete and will return process error (if any), if stderr is presented it's value will be wrapped as WorkerError. Method will return error code if php process fails to find or Start the script.

func (*Process) Write

func (w *Process) Write(p []byte) (int, error)

Worker stderr

type StateImpl

type StateImpl struct {
	// contains filtered or unexported fields
}

func NewWorkerState

func NewWorkerState(value int64) *StateImpl

NewWorkerState initializes a state for the sync.Worker

func (*StateImpl) IsActive

func (s *StateImpl) IsActive() bool

IsActive returns true if WorkerProcess not Inactive or Stopped

func (*StateImpl) LastUsed

func (s *StateImpl) LastUsed() uint64

func (*StateImpl) NumExecs

func (s *StateImpl) NumExecs() uint64

NumExecs returns number of registered WorkerProcess execs.

func (*StateImpl) RegisterExec

func (s *StateImpl) RegisterExec()

RegisterExec register new execution atomically

func (*StateImpl) Set

func (s *StateImpl) Set(value int64)

Set change StateImpl value (status)

func (*StateImpl) SetLastUsed

func (s *StateImpl) SetLastUsed(lu uint64)

SetLastUsed Update last used time

func (*StateImpl) String

func (s *StateImpl) String() string

String returns current StateImpl as string.

func (*StateImpl) Value

func (s *StateImpl) Value() int64

Value StateImpl returns StateImpl value

type Worker added in v2.12.0

type Worker struct {
	// contains filtered or unexported fields
}

func From

func From(process worker.BaseProcess) *Worker

From creates SyncWorker from BaseProcess

func (*Worker) AttachRelay added in v2.12.0

func (tw *Worker) AttachRelay(rl relay.Relay)

func (*Worker) Created added in v2.12.0

func (tw *Worker) Created() time.Time

func (*Worker) Exec added in v2.12.0

func (tw *Worker) Exec(p *payload.Payload) (*payload.Payload, error)

Exec payload without TTL timeout.

func (*Worker) ExecStream added in v2.12.0

func (tw *Worker) ExecStream(p *payload.Payload, resp chan *payload.Payload, stopCh chan struct{}) error

func (*Worker) ExecStreamWithTTL added in v2.12.0

func (tw *Worker) ExecStreamWithTTL(ctx context.Context, p *payload.Payload, resp chan *payload.Payload, stopCh chan struct{}) error

func (*Worker) ExecWithTTL added in v2.12.0

func (tw *Worker) ExecWithTTL(ctx context.Context, p *payload.Payload) (*payload.Payload, error)

ExecWithTTL executes payload without TTL timeout.

func (*Worker) Kill added in v2.12.0

func (tw *Worker) Kill() error

func (*Worker) Pid added in v2.12.0

func (tw *Worker) Pid() int64

func (*Worker) Relay added in v2.12.0

func (tw *Worker) Relay() relay.Relay

func (*Worker) Start added in v2.12.0

func (tw *Worker) Start() error

func (*Worker) State added in v2.12.0

func (tw *Worker) State() worker.State

func (*Worker) Stop added in v2.12.0

func (tw *Worker) Stop() error

func (*Worker) String added in v2.12.0

func (tw *Worker) String() string

func (*Worker) Wait added in v2.12.0

func (tw *Worker) Wait() error

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL