runner

package
v1.10.0-alpha.0 Latest Latest
Warning

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

Go to latest
Published: Dec 23, 2024 License: MPL-2.0 Imports: 15 Imported by: 0

Documentation

Overview

Package runner provides a runner for running services.

Index

Constants

View Source
const (
	// IoprioClassNone represents IOPRIO_CLASS_NONE.
	IoprioClassNone = iota
	// IoprioClassRt represents IOPRIO_CLASS_RT.
	IoprioClassRt
	// IoprioClassBe represents IOPRIO_CLASS_BE.
	IoprioClassBe
	// IoprioClassIdle represents IOPRIO_CLASS_IDLE.
	IoprioClassIdle
)
View Source
const (
	// SchedulingPolicyNormal represents SCHED_NORMAL.
	SchedulingPolicyNormal = iota
	// SchedulingPolicyFIFO represents SCHED_FIFO.
	SchedulingPolicyFIFO
	// SchedulingPolicyRR represents SCHED_RR.
	SchedulingPolicyRR
	// SchedulingPolicyBatch represents SCHED_BATCH.
	SchedulingPolicyBatch
	// SchedulingPolicyIsoUnimplemented represents SCHED_ISO.
	SchedulingPolicyIsoUnimplemented
	// SchedulingPolicyIdle represents SCHED_IDLE.
	SchedulingPolicyIdle
	// SchedulingPolicyDeadline represents SCHED_DEADLINE.
	SchedulingPolicyDeadline
)

Variables

This section is empty.

Functions

func WithMemoryReservation added in v1.8.0

func WithMemoryReservation(limit uint64) oci.SpecOpts

WithMemoryReservation sets the memory reservation limit as on OCI spec.

Types

type Args

type Args struct {
	ID          string
	ProcessArgs []string
}

Args represents the required options for services.

type IOPriorityParam added in v1.9.0

type IOPriorityParam struct {
	Class    uint
	Priority uint
}

IOPriorityParam represents the combination of IO scheduling class and priority.

type Option

type Option func(*Options)

Option is the functional option func.

func WithCgroupPath

func WithCgroupPath(path string) Option

WithCgroupPath sets the cgroup path.

func WithContainerImage

func WithContainerImage(o string) Option

WithContainerImage sets the image ref.

func WithContainerOpts

func WithContainerOpts(o ...containerd.NewContainerOpts) Option

WithContainerOpts sets the containerd container options.

func WithContainerdAddress

func WithContainerdAddress(a string) Option

WithContainerdAddress sets the containerd socket path.

func WithCtty added in v1.4.0

func WithCtty(ctty int) Option

WithCtty sets the controlling tty.

func WithCustomSeccompProfile

func WithCustomSeccompProfile(override func(*specs.LinuxSeccomp)) Option

WithCustomSeccompProfile sets the function to override seccomp profile.

func WithDroppedCapabilities added in v1.4.0

func WithDroppedCapabilities(caps map[string]struct{}) Option

WithDroppedCapabilities sets the list of capabilities to drop.

func WithEnv

func WithEnv(o []string) Option

WithEnv sets the environment variables of a service.

func WithGracefulShutdownTimeout

func WithGracefulShutdownTimeout(timeout time.Duration) Option

WithGracefulShutdownTimeout sets the timeout for the task to terminate before sending SIGKILL.

func WithIOPriority added in v1.9.0

func WithIOPriority(class, priority uint) Option

WithIOPriority sets the IO priority and class of the process.

func WithLoggingManager

func WithLoggingManager(manager runtime.LoggingManager) Option

WithLoggingManager sets the LoggingManager option.

func WithNamespace

func WithNamespace(o string) Option

WithNamespace sets the tar file to load.

func WithOCISpecOpts

func WithOCISpecOpts(o ...oci.SpecOpts) Option

WithOCISpecOpts sets the OCI spec options.

func WithOOMScoreAdj

func WithOOMScoreAdj(score int) Option

WithOOMScoreAdj sets the oom_score_adj.

func WithPriority added in v1.9.0

func WithPriority(priority int) Option

WithPriority sets the priority of the process.

func WithSchedulingPolicy added in v1.9.0

func WithSchedulingPolicy(policy uint) Option

WithSchedulingPolicy sets the scheduling policy of the process.

func WithSelinuxLabel added in v1.9.0

func WithSelinuxLabel(label string) Option

WithSelinuxLabel sets the SELinux label.

func WithStderrFile added in v1.4.0

func WithStderrFile(path string) Option

WithStderrFile sets the path to the file to use as stderr.

func WithStdin

func WithStdin(stdin io.ReadSeeker) Option

WithStdin sets the standard input.

func WithStdinFile added in v1.4.0

func WithStdinFile(path string) Option

WithStdinFile sets the path to the file to use as stdin.

func WithStdoutFile added in v1.4.0

func WithStdoutFile(path string) Option

WithStdoutFile sets the path to the file to use as stdout.

func WithUID added in v1.4.0

func WithUID(uid uint32) Option

WithUID sets the user id of the process.

type Options

type Options struct {
	// LoggingManager provides service log handling.
	LoggingManager runtime.LoggingManager
	// Env describes the service's environment variables. Elements should be in
	// the format <key=<value>
	Env []string
	// ContainerdAddress is containerd socket address.
	ContainerdAddress string
	// ContainerOpts describes the container options.
	ContainerOpts []containerd.NewContainerOpts
	// OCISpecOpts describes the OCI spec options.
	OCISpecOpts []oci.SpecOpts
	// ContainerImage is the container's image.
	ContainerImage string
	// Namespace is the containerd namespace.
	Namespace string
	// GracefulShutdownTimeout is the time to wait for process to exit after SIGTERM
	// before sending SIGKILL
	GracefulShutdownTimeout time.Duration
	// Stdin is the process standard input.
	Stdin io.ReadSeeker
	// Specify an oom_score_adj for the process.
	OOMScoreAdj int
	// CgroupPath (optional) sets the cgroup path to use
	CgroupPath string
	// OverrideSeccompProfile default Linux seccomp profile.
	OverrideSeccompProfile func(*specs.LinuxSeccomp)
	// DroppedCapabilities is the list of capabilities to drop.
	DroppedCapabilities []string
	// SelinuxLabel is the SELinux label to be assigned
	SelinuxLabel string
	// StdinFile is the path to the file to use as stdin.
	StdinFile string
	// StdoutFile is the path to the file to use as stdout.
	StdoutFile string
	// StderrFile is the path to the file to use as stderr.
	StderrFile string
	// Ctty is the controlling tty.
	Ctty optional.Optional[int]
	// UID is the user id of the process.
	UID uint32
	// Priority is the niceness value of the process.
	Priority int
	// IOPriority is the IO priority value and class of the process.
	IOPriority optional.Optional[IOPriorityParam]
	// SchedulingPolicy is the scheduling policy of the process.
	SchedulingPolicy optional.Optional[uint]
}

Options is the functional options struct.

func DefaultOptions

func DefaultOptions() *Options

DefaultOptions describes the default options to a runner.

type Runner

type Runner interface {
	fmt.Stringer
	Open() error
	Run(events.Recorder) error
	Stop() error
	Close() error
}

Runner describes the requirements for running a process.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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