Documentation ¶
Overview ¶
Package container provides an interface for interacting with Docker and potentially other container runtimes.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Container ¶ added in v0.4.1
type Container struct { // Name is the name of the container Name string // Image is the name of the container's image Image string // Status is the status of the container Status string }
Container represents a runtime container.
type ExecContainerInput ¶ added in v0.4.1
type ExecContainerInput struct { // OutputBuffer receives the stdout of the execution. OutputBuffer io.Writer // ErrorBuffer receives the stderr of the execution. ErrorBuffer io.Writer // InputBuffer contains stdin or nil if no input. InputBuffer io.Reader // EnvironmentVars is a collection of name=values to pass as environment variables in the container. EnvironmentVars []string }
ExecContainerInput contains values for running exec on a container.
type FilterBuilder ¶ added in v0.4.1
FilterBuilder is a helper for building up filter strings of "key=value" or "key=name=value".
func (FilterBuilder) AddKeyNameValue ¶ added in v0.4.1
func (f FilterBuilder) AddKeyNameValue(key, name, value string)
AddKeyNameValue adds a filter with a name=value (--filter "label=io.x-k8s.kind.cluster=quick-start-n95t5z").
func (FilterBuilder) AddKeyValue ¶ added in v0.4.1
func (f FilterBuilder) AddKeyValue(key, value string)
AddKeyValue adds a filter with a single name (--filter "label=io.x-k8s.kind.cluster").
type Mount ¶ added in v0.4.1
type Mount struct { // Source is the source host path to mount. Source string // Target is the path to mount in the container. Target string // ReadOnly specifies if the mount should be mounted read only. ReadOnly bool }
Mount contains mount details.
type PortMapping ¶ added in v0.4.1
type PortMapping struct { // ContainerPort is the port in the container to map to. ContainerPort int32 // HostPort is the port to expose on the host. HostPort int32 // ListenAddress is the address to bind to. ListenAddress string // Protocol is the protocol (tcp, udp, etc.) to use. Protocol string }
PortMapping contains port mapping information for the container.
type RunContainerInput ¶
type RunContainerInput struct { // Image is the name of the image to run. Image string // Name is the name to set for the container. Name string // Network is the name of the network to connect to. Network string // User is the user name to run as. User string // Group is the user group to run as. Group string // Volumes is a collection of any volumes (docker's "-v" arg) to mount in the container. Volumes map[string]string // Tmpfs is the temporary filesystem mounts to add. Tmpfs map[string]string // Mount contains mount information for the container. Mounts []Mount // EnvironmentVars is a collection of name/values to pass as environment variables in the container. EnvironmentVars map[string]string // CommandArgs is the command and any additional arguments to execute in the container. CommandArgs []string // Entrypoint defines the entry point to use. Entrypoint []string // Labels to apply to the container. Labels map[string]string // PortMappings contains host<>container ports to map. PortMappings []PortMapping // IPFamily is the IP version to use. IPFamily clusterv1.ClusterIPFamily }
RunContainerInput holds the configuration settings for running a container.
type Runtime ¶ added in v0.4.1
type Runtime interface { SaveContainerImage(ctx context.Context, image, dest string) error PullContainerImageIfNotExists(ctx context.Context, image string) error GetHostPort(ctx context.Context, containerName, portAndProtocol string) (string, error) GetContainerIPs(ctx context.Context, containerName string) (string, string, error) ExecContainer(ctx context.Context, containerName string, config *ExecContainerInput, command string, args ...string) error RunContainer(ctx context.Context, runConfig *RunContainerInput, output io.Writer) error ListContainers(ctx context.Context, filters FilterBuilder) ([]Container, error) ContainerDebugInfo(ctx context.Context, containerName string, w io.Writer) error DeleteContainer(ctx context.Context, containerName string) error KillContainer(ctx context.Context, containerName, signal string) error }
Runtime defines the interface for interacting with a container runtime.
func NewDockerClient ¶
NewDockerClient gets a client for interacting with a Docker container runtime.