Documentation
¶
Index ¶
- Constants
- Variables
- func ConmonPath(r *Runtime) string
- func ReadConmonPidFile(c *Container) (int, error)
- type Container
- func (c *Container) AddVolume(v ContainerVolume)
- func (c *Container) Annotations() map[string]string
- func (c *Container) BundlePath() string
- func (c *Container) CleanupConmonCgroup()
- func (c *Container) ConmonCgroupfsPath() string
- func (c *Container) Created() bool
- func (c *Container) CreatedAt() time.Time
- func (c *Container) CrioAnnotations() map[string]string
- func (c *Container) Description() string
- func (c *Container) Dir() string
- func (c *Container) FromDisk() error
- func (c *Container) GetStopSignal() string
- func (c *Container) ID() string
- func (c *Container) IDMappings() *idtools.IDMappings
- func (c *Container) Image() string
- func (c *Container) ImageName() string
- func (c *Container) ImageRef() string
- func (c *Container) Labels() map[string]string
- func (c *Container) LogPath() string
- func (c *Container) Metadata() *pb.ContainerMetadata
- func (c *Container) MountPoint() string
- func (c *Container) Name() string
- func (c *Container) Sandbox() string
- func (c *Container) SeccompProfilePath() string
- func (c *Container) SetCreated()
- func (c *Container) SetIDMappings(mappings *idtools.IDMappings)
- func (c *Container) SetMountPoint(mp string)
- func (c *Container) SetSeccompProfilePath(pp string)
- func (c *Container) SetSpec(s *specs.Spec)
- func (c *Container) SetStartFailed(err error)
- func (c *Container) ShouldBeStopped() error
- func (c *Container) Spec() specs.Spec
- func (c *Container) State() *ContainerState
- func (c *Container) StateNoLock() *ContainerState
- func (c *Container) StatePath() string
- func (c *Container) StdinOnce() bool
- func (c *Container) StopSignal() syscall.Signal
- func (c *Container) Volumes() []ContainerVolume
- type ContainerState
- type ContainerStats
- type ContainerStorer
- type ContainerVolume
- type ExecSyncError
- type ExecSyncResponse
- type History
- type Runtime
- func (r *Runtime) AttachContainer(c *Container, inputStream io.Reader, outputStream, errorStream io.WriteCloser, ...) error
- func (r *Runtime) ContainerRuntimeType(c *Container) (string, error)
- func (r *Runtime) ContainerStats(c *Container, cgroup string) (*ContainerStats, error)
- func (r *Runtime) CreateContainer(c *Container, cgroupParent string) error
- func (r *Runtime) DeleteContainer(c *Container) error
- func (r *Runtime) ExecContainer(c *Container, cmd []string, stdin io.Reader, stdout, stderr io.WriteCloser, ...) error
- func (r *Runtime) ExecSyncContainer(c *Container, command []string, timeout int64) (*ExecSyncResponse, error)
- func (r *Runtime) PauseContainer(c *Container) error
- func (r *Runtime) PortForwardContainer(c *Container, port int32, stream io.ReadWriter) error
- func (r *Runtime) PrivilegedWithoutHostDevices(handler string) (bool, error)
- func (r *Runtime) ReopenContainerLog(c *Container) error
- func (r *Runtime) RuntimeImpl(c *Container) (RuntimeImpl, error)
- func (r *Runtime) Runtimes() config.Runtimes
- func (r *Runtime) SignalContainer(c *Container, sig syscall.Signal) error
- func (r *Runtime) SpoofOOM(c *Container)
- func (r *Runtime) StartContainer(c *Container) error
- func (r *Runtime) StopContainer(ctx context.Context, c *Container, timeout int64) error
- func (r *Runtime) UnpauseContainer(c *Container) error
- func (r *Runtime) UpdateContainer(c *Container, res *rspec.LinuxResources) error
- func (r *Runtime) UpdateContainerStatus(c *Container) error
- func (r *Runtime) ValidateRuntimeHandler(handler string) (*config.RuntimeHandler, error)
- func (r *Runtime) WaitContainerStateStopped(ctx context.Context, c *Container) error
- type RuntimeImpl
- type StoreFilter
- type StoreReducer
Constants ¶
const ( AttachPipeStdin = 1 AttachPipeStdout = 2 AttachPipeStderr = 3 )
Sync with stdpipe_t in conmon.c
const ( // ContainerStateCreated represents the created state of a container ContainerStateCreated = "created" // ContainerStatePaused represents the paused state of a container ContainerStatePaused = "paused" // ContainerStateRunning represents the running state of a container ContainerStateRunning = "running" // ContainerStateStopped represents the stopped state of a container ContainerStateStopped = "stopped" // ContainerCreateTimeout represents the value of container creating timeout ContainerCreateTimeout = 240 * time.Second // CgroupfsCgroupsManager represents cgroupfs native cgroup manager CgroupfsCgroupsManager = "cgroupfs" // SystemdCgroupsManager represents systemd native cgroup manager SystemdCgroupsManager = "systemd" // CrioScopePrefix is the crio specific scope prefix // used for container cgroups CrioScopePrefix = "crio" )
const (
// RuntimeTypeOCI is the type representing the RuntimeOCI implementation.
RuntimeTypeOCI = "oci"
)
Variables ¶
var ErrContainerStopped = errors.New("container is already stopped")
Functions ¶
func ConmonPath ¶ added in v1.16.2
func ReadConmonPidFile ¶ added in v1.16.2
ReadConmonPidFile attempts to read conmon's pid from its pid file This function makes no verification that this file should exist it is up to the caller to verify that this container has a conmon
Types ¶
type Container ¶
type Container struct {
// contains filtered or unexported fields
}
Container represents a runtime container.
func NewContainer ¶
func NewContainer(id, name, bundlePath, logPath string, labels, crioAnnotations, annotations map[string]string, image, imageName, imageRef string, metadata *pb.ContainerMetadata, sandbox string, terminal, stdin, stdinOnce bool, runtimeHandler, dir string, created time.Time, stopSignal string) (*Container, error)
NewContainer creates a container object.
func (*Container) AddVolume ¶
func (c *Container) AddVolume(v ContainerVolume)
AddVolume adds a volume to list of container volumes.
func (*Container) Annotations ¶
Annotations returns the annotations of the container.
func (*Container) BundlePath ¶
BundlePath returns the bundlePath of the container.
func (*Container) CleanupConmonCgroup ¶
func (c *Container) CleanupConmonCgroup()
CleanupConmonCgroup cleans up conmon's group when using cgroupfs.
func (*Container) ConmonCgroupfsPath ¶
ConmonCgroupfsPath returns the path to conmon's cgroup. This is only set when cgroupfs is used as a cgroup manager.
func (*Container) CrioAnnotations ¶
CrioAnnotations returns the crio annotations of the container.
func (*Container) Description ¶
Description returns a description for the container
func (*Container) GetStopSignal ¶
GetStopSignal returns the container's own stop signal configured from the image configuration or the default one.
func (*Container) IDMappings ¶
func (c *Container) IDMappings() *idtools.IDMappings
IDMappings returns the ID/GID mappings used for the container
func (*Container) Metadata ¶
func (c *Container) Metadata() *pb.ContainerMetadata
Metadata returns the metadata of the container.
func (*Container) MountPoint ¶
MountPoint returns the container mount point
func (*Container) SeccompProfilePath ¶
SeccompProfilePath returns the seccomp profile path
func (*Container) SetCreated ¶
func (c *Container) SetCreated()
SetCreated sets the created flag to true once container is created
func (*Container) SetIDMappings ¶
func (c *Container) SetIDMappings(mappings *idtools.IDMappings)
SetIDMappings sets the ID/GID mappings used for the container
func (*Container) SetMountPoint ¶
SetMountPoint sets the container mount point
func (*Container) SetSeccompProfilePath ¶
SetSeccompProfilePath sets the seccomp profile path
func (*Container) SetStartFailed ¶
SetStartFailed sets the container state appropriately after a start failure
func (*Container) ShouldBeStopped ¶ added in v1.17.5
ShouldBeStopped checks whether the container state is in a place where attempting to stop it makes sense a container is not stoppable if it's paused or stopped if it's paused, that's an error, and is reported as such
func (*Container) State ¶
func (c *Container) State() *ContainerState
State returns the state of the running container
func (*Container) StateNoLock ¶
func (c *Container) StateNoLock() *ContainerState
StateNoLock returns the state of a container without using a lock.
func (*Container) StopSignal ¶
StopSignal returns the container's own stop signal configured from the image configuration or the default one.
func (*Container) Volumes ¶
func (c *Container) Volumes() []ContainerVolume
Volumes returns the list of container volumes.
type ContainerState ¶
type ContainerState struct { specs.State Created time.Time `json:"created"` Started time.Time `json:"started,omitempty"` Finished time.Time `json:"finished,omitempty"` ExitCode *int32 `json:"exitCode,omitempty"` OOMKilled bool `json:"oomKilled,omitempty"` Error string `json:"error,omitempty"` }
ContainerState represents the status of a container.
type ContainerStats ¶
type ContainerStats struct { Container string CPU float64 CPUNano uint64 SystemNano int64 MemUsage uint64 MemLimit uint64 MemPerc float64 NetInput uint64 NetOutput uint64 BlockInput uint64 BlockOutput uint64 PIDs uint64 WorkingSetBytes uint64 }
ContainerStats contains the statistics information for a running container
type ContainerStorer ¶
type ContainerStorer interface { // Add appends a new container to the store. Add(string, *Container) // Get returns a container from the store by the identifier it was stored with. Get(string) *Container // Delete removes a container from the store by the identifier it was stored with. Delete(string) // List returns a list of containers from the store. List() []*Container // Size returns the number of containers in the store. Size() int // First returns the first container found in the store by a given filter. First(StoreFilter) *Container // ApplyAll calls the reducer function with every container in the store. ApplyAll(StoreReducer) }
ContainerStorer defines an interface that any container store must implement.
func NewMemoryStore ¶
func NewMemoryStore() ContainerStorer
NewMemoryStore initializes a new memory store.
type ContainerVolume ¶
type ContainerVolume struct { ContainerPath string `json:"container_path"` HostPath string `json:"host_path"` Readonly bool `json:"readonly"` }
ContainerVolume is a bind mount for the container.
type ExecSyncError ¶
ExecSyncError wraps command's streams, exit code and error on ExecSync error.
func (*ExecSyncError) Error ¶
func (e *ExecSyncError) Error() string
type ExecSyncResponse ¶
ExecSyncResponse is returned from ExecSync.
type History ¶
type History []*Container
History is a convenience type for storing a list of containers, sorted by creation date in descendant order.
type Runtime ¶
type Runtime struct {
// contains filtered or unexported fields
}
Runtime is the generic structure holding both global and specific information about the runtime.
func (*Runtime) AttachContainer ¶
func (r *Runtime) AttachContainer(c *Container, inputStream io.Reader, outputStream, errorStream io.WriteCloser, tty bool, resize <-chan remotecommand.TerminalSize) error
AttachContainer attaches IO to a running container.
func (*Runtime) ContainerRuntimeType ¶ added in v1.16.2
ContainerRuntimeType returns the type of runtime configured. This is needed when callers need to do specific work for oci vs vm containers, like monitor an oci container's conmon.
func (*Runtime) ContainerStats ¶
func (r *Runtime) ContainerStats(c *Container, cgroup string) (*ContainerStats, error)
ContainerStats provides statistics of a container.
func (*Runtime) CreateContainer ¶
CreateContainer creates a container.
func (*Runtime) DeleteContainer ¶
DeleteContainer deletes a container.
func (*Runtime) ExecContainer ¶
func (r *Runtime) ExecContainer(c *Container, cmd []string, stdin io.Reader, stdout, stderr io.WriteCloser, tty bool, resize <-chan remotecommand.TerminalSize) error
ExecContainer prepares a streaming endpoint to execute a command in the container.
func (*Runtime) ExecSyncContainer ¶
func (r *Runtime) ExecSyncContainer(c *Container, command []string, timeout int64) (*ExecSyncResponse, error)
ExecSyncContainer execs a command in a container and returns it's stdout, stderr and return code.
func (*Runtime) PauseContainer ¶
PauseContainer pauses a container.
func (*Runtime) PortForwardContainer ¶
PortForwardContainer forwards the specified port provides statistics of a container.
func (*Runtime) PrivilegedWithoutHostDevices ¶ added in v1.16.2
PrivelegedRuntimeHandler returns a boolean value configured for the runtimeHandler indicating if devices on the host are passed/not passed to a container running as privileged.
func (*Runtime) ReopenContainerLog ¶
ReopenContainerLog reopens the log file of a container.
func (*Runtime) RuntimeImpl ¶
func (r *Runtime) RuntimeImpl(c *Container) (RuntimeImpl, error)
RuntimeImpl returns the runtime implementation for a given container
func (*Runtime) SignalContainer ¶
SignalContainer sends a signal to a container process.
func (*Runtime) SpoofOOM ¶ added in v1.16.2
SpoofOOM is a function that sets a container state as though it OOM'd. It's used in situations where another process in the container's cgroup (like conmon) OOM'd when it wasn't supposed to, allowing us to report to the kubelet that the container OOM'd instead.
func (*Runtime) StartContainer ¶
StartContainer starts a container.
func (*Runtime) StopContainer ¶
StopContainer stops a container. Timeout is given in seconds.
func (*Runtime) UnpauseContainer ¶
UnpauseContainer unpauses a container.
func (*Runtime) UpdateContainer ¶
func (r *Runtime) UpdateContainer(c *Container, res *rspec.LinuxResources) error
UpdateContainer updates container resources
func (*Runtime) UpdateContainerStatus ¶
UpdateContainerStatus refreshes the status of the container.
func (*Runtime) ValidateRuntimeHandler ¶
func (r *Runtime) ValidateRuntimeHandler(handler string) (*config.RuntimeHandler, error)
ValidateRuntimeHandler returns an error if the runtime handler string provided does not match any valid use case.
func (*Runtime) WaitContainerStateStopped ¶
WaitContainerStateStopped runs a loop polling UpdateStatus(), seeking for the container status to be updated to 'stopped'. Either it gets the expected status and returns nil, or it reaches the timeout and returns an error.
type RuntimeImpl ¶
type RuntimeImpl interface { CreateContainer(*Container, string) error StartContainer(*Container) error ExecContainer(*Container, []string, io.Reader, io.WriteCloser, io.WriteCloser, bool, <-chan remotecommand.TerminalSize) error ExecSyncContainer(*Container, []string, int64) (*ExecSyncResponse, error) UpdateContainer(*Container, *rspec.LinuxResources) error StopContainer(context.Context, *Container, int64) error DeleteContainer(*Container) error UpdateContainerStatus(*Container) error PauseContainer(*Container) error UnpauseContainer(*Container) error ContainerStats(*Container, string) (*ContainerStats, error) SignalContainer(*Container, syscall.Signal) error AttachContainer(*Container, io.Reader, io.WriteCloser, io.WriteCloser, bool, <-chan remotecommand.TerminalSize) error PortForwardContainer(*Container, int32, io.ReadWriter) error ReopenContainerLog(*Container) error WaitContainerStateStopped(context.Context, *Container) error }
RuntimeImpl is an interface used by the caller to interact with the container runtime. The purpose of this interface being to abstract implementations and their associated assumptions regarding the way to interact with containers. This will allow for new implementations of this interface, especially useful for the case of VM based container runtimes. Assumptions based on the fact that a container process runs on the host will be limited to the RuntimeOCI implementation.
type StoreFilter ¶
StoreFilter defines a function to filter container in the store.
type StoreReducer ¶
type StoreReducer func(*Container)
StoreReducer defines a function to manipulate containers in the store