Ever since version 0.0.10, all newly created toolbox containers use a reflexive entry point [1] and don't need a user-specific customized image. Older containers that don't use a reflexive entry point were deprecated in version 0.0.17 [2], and aren't even supported in the Go implementation. Therefore, it's time to finally update the manuals to document the current way of doing things. Since the reflexive entry point is a key feature of toolbox containers, some text was added to explain why it's necessary and what it does. [1] Commit8b84b5e460
https://github.com/containers/toolbox/pull/160 [2] Commit9dc5281430
https://github.com/containers/toolbox/pull/336 https://github.com/containers/toolbox/pull/677
3 KiB
% toolbox-init-container(1)
NAME
toolbox-init-container - Initialize a running container
SYNOPSIS
toolbox init-container --home HOME --home-link --media-link --mnt-link --monitor-host --shell SHELL --uid UID --user USER
DESCRIPTION
Initializes a newly created container that's running. It is primarily meant to be used as the entry point for all toolbox containers, and must be run inside the container that's to be initialized. It is not expected to be directly invoked by humans, and cannot be used on the host.
A key feature of toolbox containers is their entry point, the toolbox init-container
command.
OCI containers are inherently immutable. Configuration options passed through
podman create
are baked into the definition of the OCI container, and can't
be changed later. This means that changes and improvements made in newer
versions of Toolbox can't be applied to pre-existing toolbox containers
created by older versions of Toolbox. This is avoided by using the entry point
to configure the container at runtime.
The entry point of a toolbox container customizes the container to fit the
current user by ensuring that it has a user that matches the one on the host.
It ensures that configuration files, such as /etc/host.conf
, /etc/hosts
,
/etc/localtime
, /etc/resolv.conf
and /etc/timezone
, inside the container
are kept synchronized with the host. The entry point also bind mounts various
subsets of the host's filesystem hierarchy to their corresponding locations
inside the container to provide seamless integration with the host. This
includes /run/libvirt
, /run/systemd/journal
, /run/udev/data
,
/var/lib/libvirt
, /var/lib/systemd/coredump
, /var/log/journal
and others.
On some host operating systems, important paths like /home
, /media
or
/mnt
are symbolic links to other locations. The entry point ensures that
paths inside the container match those on the host, to avoid needless
confusion.
OPTIONS
The following options are understood:
--home HOME
Create a user inside the toolbox container whose login directory is HOME.
--home-link
Make /home
a symbolic link to /var/home
.
--media-link
Make /media
a symbolic link to /run/media
.
--mnt-link
Make /mnt
a symbolic link to /var/mnt
.
--monitor-host
Ensure that certain configuration files inside the toolbox container are kept
synchronized with their counterparts on the host. Currently, these files are
/etc/hosts
and /etc/resolv.conf
.
--shell SHELL
Create a user inside the toolbox container whose login shell is SHELL.
--uid UID
Create a user inside the toolbox container whose numerical user ID is UID.
--user USER
Create a user inside the toolbox container whose login name is LOGIN.
SEE ALSO
podman(1)
, podman-create(1)
, podman-start(1)