Documentation ¶
Overview ¶
Package dockerutil contains convenience functions for interacting with Docker.
Index ¶
- Constants
- Variables
- func BootstrapContainer(ctx context.Context, client Client, conf BootstrapConfig) error
- func BridgeIPFromCIDR(cidr string) (net.IP, int)
- func CreateContainer(ctx context.Context, client Client, conf *ContainerConfig) (string, error)
- func DefaultLogImagePullFn(log buildlog.Logger) func(ImagePullEvent) error
- func ExecContainer(ctx context.Context, client Client, config ExecConfig) ([]byte, error)
- func PruneImages(ctx context.Context, client Client) (dockertypes.ImagesPruneReport, error)
- func PullImage(ctx context.Context, config *PullImageConfig) error
- func SetContainerQuota(ctx context.Context, containerID string, quota xunix.CPUQuota) error
- func WaitForDaemon(ctx context.Context, client Client) error
- func WithClient(ctx context.Context, client Client) context.Context
- func WriteCertsForRegistry(ctx context.Context, registryName, certsDir string) error
- type AuthConfig
- type BootstrapConfig
- type Client
- type ContainerConfig
- type ExecConfig
- type ImageMetadata
- type ImagePullEvent
- type ImagePullProgressFn
- type PullImageConfig
Constants ¶
const ( // Default CPU period for containers. DefaultCPUPeriod uint64 = 1e5 )
Variables ¶
var DefaultBridgeCIDR = "172.19.0.1/30"
Functions ¶
func BootstrapContainer ¶
func BootstrapContainer(ctx context.Context, client Client, conf BootstrapConfig) error
BoostrapContainer runs a script inside the container as the provided user. If conf.Script is empty then it is a noop.
func CreateContainer ¶
CreateContainer creates a sysbox-runc container.
func DefaultLogImagePullFn ¶
func DefaultLogImagePullFn(log buildlog.Logger) func(ImagePullEvent) error
func ExecContainer ¶
ExecContainer runs a command in a container. It returns the output and any error. If an error occurs during the execution of the command, the output is appended to the error.
func PruneImages ¶
func PruneImages(ctx context.Context, client Client) (dockertypes.ImagesPruneReport, error)
PruneImage runs a simple 'docker prune'.
func PullImage ¶
func PullImage(ctx context.Context, config *PullImageConfig) error
PullImage pulls the provided image.
func SetContainerQuota ¶
SetContainerQuota writes a quota to its correct location for the inner container. HACK: until https://github.com/nestybox/sysbox/issues/582 is resolved, we need to copy the CPU quota and period from the outer container to the inner container to ensure that applications inside the container know how much CPU they have to work with.
For cgroupv2: - /sys/fs/cgroup/<subpath>/init.scope/cpu.max
For cgroupv1: - /sys/fs/cgroup/cpu,cpuacct/<subpath>/syscont-cgroup-root/cpu.cfs_quota_us - /sys/fs/cgroup/cpu,cpuacct/<subpath>/syscont-cgroup-root/cpu.cfs_period_us
func WaitForDaemon ¶
WaitForDaemon waits for a Docker daemon to startup. It waits a max of 5m before giving up.
func WithClient ¶
WithClient sets the provided DockerClient on the context. It should only be used for tests.
func WriteCertsForRegistry ¶
WriteCertsForRegistry writes the certificates found in the provided directory to the correct subdirectory that the Docker daemon uses when pulling images from the specified private registry.
Types ¶
type AuthConfig ¶
type AuthConfig registry.AuthConfig
func AuthConfigFromPath ¶
func AuthConfigFromPath(path string, reg string) (AuthConfig, error)
func AuthConfigFromString ¶
func AuthConfigFromString(raw string, reg string) (AuthConfig, error)
func (AuthConfig) Base64 ¶
func (a AuthConfig) Base64() (string, error)
type BootstrapConfig ¶
type Client ¶
type Client interface { dockerclient.SystemAPIClient dockerclient.ContainerAPIClient dockerclient.ImageAPIClient }
type ContainerConfig ¶
type ContainerConfig struct { Log slog.Logger Mounts []xunix.Mount Devices []container.DeviceMapping Envs []string Name string Image string WorkingDir string Hostname string // HasInit dictates whether the entrypoint of the container is /sbin/init // or 'sleep infinity'. HasInit bool CPUs int64 MemoryLimit int64 }
type ExecConfig ¶
type ImageMetadata ¶
func GetImageMetadata ¶
func GetImageMetadata(ctx context.Context, client Client, img, username string) (ImageMetadata, error)
GetImageMetadata returns metadata about an image such as the UID/GID of the provided username and whether it contains an /sbin/init that we should run.
type ImagePullEvent ¶
type ImagePullProgressFn ¶
type ImagePullProgressFn func(e ImagePullEvent) error
ImagePullProgressFn provides a way for a consumer to process image pull progress.
type PullImageConfig ¶
type PullImageConfig struct { Client Client Image string Auth AuthConfig ProgressFn ImagePullProgressFn }
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package dockerfake contains logic for mocking out Docker-related functionality.
|
Package dockerfake contains logic for mocking out Docker-related functionality. |