Podman is a lot like Docker: a tool for running OCI containers. While it maintains backwards compatibility with Dockerfile and docker-compose syntax, it offers a lot of other benefits:

  • daemonless: it can run containers without a daemon process running in the background.
  • Rootless: can run containers without root privileges
  • pods: can group containers into secluded pods, which share resources and network namespace

Podman has other features I haven’t explored yet, like compatibility with Kubernetes yaml file, and being able to run containers as systemd units.

Have you used podman before? What are your thoughts on it?

    • 0x442e472e@feddit.de
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      I’m very interested in a solution. Our current setup, where we use an external docker host for Testcontainers and Podman to build images is quite painful

      • agilob
        link
        fedilink
        English
        arrow-up
        1
        ·
        1 year ago

        I have this on my to-do list, but sorry, can’t promise when I’ll make a working demo. afair the trick was to use something like “podman in-podman”, like dind works in GitLab runners and then some env-vars manipulation so TC thinks it runs in docker, something like

        DOCKER_HOST=unix:///run/user/1000/podman/podman.sock and I use alpine as gitlab-ci helper image:

                image = "docker.io/alpine:3.17.2"
                helper_image_flavor = "alpine"
        

        not sure if that matters, but i had lots of strange problems running with Ubuntu helper images, most were DNS propagation issues