Documentation ¶
Index ¶
Constants ¶
View Source
const ( NotFound = "NotFound" Running = "Running" Stopped = "Stopped" )
Variables ¶
View Source
var ContainerRuntimes = map[string]Initializer{}
Functions ¶
func Register ¶ added in v0.15.0
func Register(name string, initFn Initializer)
func WaitForContainerRunning ¶ added in v0.33.0
func WaitForContainerRunning(ctx context.Context, r ContainerRuntime, contName, nodeName string) error
WaitForContainerRunning waits for container to become running by polling its status.
Types ¶
type ContainerRuntime ¶
type ContainerRuntime interface { // Initializes the Container runtime struct Init(...RuntimeOption) error // Mgmt return management network configuration of a runtime Mgmt() *types.MgmtNet // Adds custom configuration items to the container runtime struct WithConfig(*RuntimeConfig) // Set the network management details (generated by the config.go) WithMgmtNet(*types.MgmtNet) // Instructs the runtime not to delete the mgmt network on destroy WithKeepMgmtNet() // Create container (bridge) network CreateNet(context.Context) error // Delete container (bridge) network DeleteNet(context.Context) error // Pull container image if not present PullImageIfRequired(context.Context, string) error // CreateContainer creates a container, but does not start it CreateContainer(context.Context, *types.NodeConfig) (string, error) // Start pre-created container by its name. Returns an extra interface that can be used to receive signals // about the container life-cycle after it was created, e.g. for post-deploy tasks StartContainer(context.Context, string, *types.NodeConfig) (interface{}, error) // Stop running container by its name StopContainer(context.Context, string) error // Pause a container identified by its name PauseContainer(context.Context, string) error // UnPause / resume a container identified by its name UnpauseContainer(context.Context, string) error // List all containers matching labels ListContainers(context.Context, []*types.GenericFilter) ([]types.GenericContainer, error) // Get a netns path using the pid of a container GetNSPath(context.Context, string) (string, error) // Executes cmd on container identified with id and returns stdout, stderr bytes and an error Exec(ctx context.Context, cID string, execCmd *exec.ExecCmd) (exec.ExecResultHolder, error) // ExecNotWait executes cmd on container identified with id but doesn't wait for output nor attaches stdout/err ExecNotWait(ctx context.Context, cID string, execCmd *exec.ExecCmd) error // Delete container by its name DeleteContainer(context.Context, string) error // Getter for runtime config options Config() RuntimeConfig GetName() string // GetHostsPath returns fs path to a file which is mounted as /etc/hosts into a given container GetHostsPath(context.Context, string) (string, error) // GetContainerStatus retrieves the ContainerStatus of the named container GetContainerStatus(ctx context.Context, cID string) ContainerStatus }
type ContainerStatus ¶ added in v0.32.0
type ContainerStatus string
type Initializer ¶ added in v0.15.0
type Initializer func() ContainerRuntime
type RuntimeConfig ¶ added in v0.15.0
type RuntimeOption ¶ added in v0.15.0
type RuntimeOption func(ContainerRuntime)
func WithConfig ¶ added in v0.15.0
func WithConfig(cfg *RuntimeConfig) RuntimeOption
func WithKeepMgmtNet ¶ added in v0.15.0
func WithKeepMgmtNet() RuntimeOption
func WithMgmtNet ¶ added in v0.15.0
func WithMgmtNet(mgmt *types.MgmtNet) RuntimeOption
Click to show internal directories.
Click to hide internal directories.