Skip to content

Latest commit

 

History

History
58 lines (43 loc) · 2.43 KB

README.md

File metadata and controls

58 lines (43 loc) · 2.43 KB

modern containers

Components: podman, crun, buildah, podman-compose, gui support via x11docker

containers.lib

  • easy rootless support with user !=''

  • create a data volume

    • volume(volume_name, opts=[], labels={}, driver='local', user='')
  • get full path of a volume

    • volume_path(volume_name, container_or_compose_definition, user='')
  • pull or build an image

    • image(image_name, tag='', source='', buildargs={}, builddir= '', user='')
  • start/prepare a container as systemd service/oneshot by pulling/building and optionally starting a container

    • container(container_definition, user='')
  • start a compose structure as systemd service by pulling/building and starting a compose structure

    • compose(compose_definition, user='')

configure

  • see defaults.jinja for details and comments of default_container and default_compose
  • container types: "build", "service", "oneshot", "command", "desktop"
  • compose types: "service", "oneshot"
  • computed environment
    • entry:environment:SERVICE_NAME=entry.name, USER, HOME, USERNS_ID
    • entry:desktop:template_options=settings.x11docker[entry.desktop.template]
    • entry:configdir, workdir, builddir, servicedir, scriptdir, desktopdir
    • container type: replace ${} vars in: environment, labels, storage, volumes, ports

Unsorted Notes

  • extract config from docker/compose daemon https://github.com/nginx-proxy/docker-gen

  • The podman run and podman create commands now feature a --sdnotify option to control the behavior of systemd's sdnotify with containers, enabling improved support for Podman in Type=notify units.

  • Podman with the crun OCI runtime now supports a new option to podman run and podman create, --cgroup-conf, which allows for advanced configuration of cgroups on cgroups v2 systems.

  • Podman can be easily run as a normal user, without requiring a setuid binary. When run without root, Podman containers use user namespaces to set root in the container to the user running Podman. Rootless Podman runs locked-down containers with no privileges that the user running the container does not have. Some of these restrictions can be lifted (via --privileged, for example), but rootless containers will never have more privileges than the user that launched them. If you run Podman as your user and mount in /etc/passwd from the host, you still won't be able to change it, since your user doesn't have permission to do so.