10 comments

  • kuratkull 64 days ago
    Podman actually works really well. Out-of-the-box virtually-no-configuration-needed rootless containers. It's also usable via docker-compose with a single env variable. (podman-compose wasn't up to par for us)

    We've been using it for a couple of years running and managing hundreds of containers per server - no feeling of flakiness whatsoever. It's virtually zeroconf and even supports GPUs for those who need it. It's like docker but better, IMO.

    Hope it gets a popularity boost from CNCF. Rooting for it.

    • zamalek 64 days ago
      I vastly prefer it to Docker, especially buildah over buildx. Instead of inventing yet-another-dsl buildah allows you to simply use shell scripts (though it does also support dockerfiles). Another thing buildah is really good at is not doing much automatically: you can really optimize layers if you care to.

      The Podman ecosystem has given me a strong disliking of the Docker ecosystem, so I'm also rooting for it.

      • ryan29 64 days ago
        I think I might be the only one that prefers Docker for building Docker containers using CI.

        I use Drone, but instead of using the Docker plugin I start a detached (background) Caddy server to work as a proxy to DOCKER_HOST. That lets me proxy to the local Docker socket to take advantage of caching, etc. while I'm iterating, but gives the option of spinning up docker-in-docker to get a clean environment, without any caching, and running a slower build that virtually identical to what happens on the CI server.

        I find that having the daemon available solves a ton of issues that most of the CI provided builder plugins have. For example, with the builder plugins I'd always end up with a step like build-and-tag-and-push which didn't work very well for me. Now I can run discreet build steps like build, test, tag, push and it feels far more intuitive, at least to me.

    • papichulo2023 64 days ago
      I only dislike Podman because some distributions used it as an alias for docker which made a lot of docker-compatible software to not work on that distribution unless some workarounds. I wouldnt normally blame the application for this but in this case they are both, application and distribution, from the same dev.
      • colechristensen 64 days ago
        Agreed, the `podman` command is 95% drop-in compatible with the `docker` command, but those edge cases are annoying and I would rather just use the docker cli backed with podman running the containers.
        • tristan957 64 days ago
          Podman has a docker frontend. On Fedora, it is packaged as podman-docker, I believe. I recently went through the pain of getting testcontainers working on Fedora 41 with Podman. After enabling the Podman socket and setting an environment variables, I was off to the races!
    • jeppester 64 days ago
      I completely agree and have had the same experience as you with docker-compose working better than the alternatives.

      Past versions of podman were flaky, but since version 4, which is now a couple of years old, I haven't had any issues whatsoever. I'd recommend anyone using containers on linux to try it out instead of installing docker out of habit.

    • righthand 64 days ago
      If podman compose would parse env var strings correctly, then it would be on par. Not sure why that hasn’t been fixed but probably because it’s a stepping stone instead of a well thought out replacement.
    • bombela 64 days ago
      The IO through fuse-overlay is performance limiting though. It's almost half the speed as overlay directly for layers with many tiny files.

      Note that Linux allows you to mount overlay within a user namespace if you are root within the user namespace.

      In other words, if you are root within a container; even though it is not root on the host; Linux accepte ton mount overlay filesystems (most filesystems are not allowed). `man user_namespace`

    • forabi 64 days ago
      > Rooting for it.

      I wanted to say something funny about "rooting" and "rootless", but it's probably too silly. :)

      • msgilligan 64 days ago
        Ruthlessly rooting for rootless!
    • Cyph0n 64 days ago
      +1, Podman is great. I have been running it for a while on NixOS.

      But Compose doesn’t mesh well with the overall NixOS configuration system. So I ended up building a custom tool that can convert your existing Compose project into a NixOS config.

    • mattgreenrocks 64 days ago
      Dumb question: is it rootless for users on something like macOS?

      I'd love to get the benefits of Docker without the battery drain and the Docker software, but I'm not sure if Podman would help much with either.

      • goalieca 64 days ago
        On macOS it creates a centos VM to run containers in. Rootless simply means that the root user in a container maps to the runner outside and not as the actual system root.

        Edit: .. because the runner is not needing to run as root

    • dbacar 64 days ago
      > docker-compose with a single env variable what is that env variable?
    • bityard 64 days ago
      > It's also usable via docker-compose

      Is that "docker-compose" (with a dash) or "docker compose" (with a space)?

      • whilenot-dev 64 days ago
        Both should do exacly the same, they are just installed differently. docker compose is installed as docker CLI plugin (Linux only), and docker-compose is installed as standalone binary.

        See ref: https://docs.docker.com/compose/install/#scenario-two-instal...

        • tristan957 64 days ago
          There are subtle differences between the two and not exactly the same.
          • whilenot-dev 64 days ago
            That would be news to me, as both are pointing to the exact same GitHub repository[0]. Can you name the differences?

            [0]: https://github.com/docker/compose

            • thangngoc89 64 days ago
              Previous docker-compose was a separate program, written in Python if I remember correctly, people usually preferred to them as v1. Later docker incorporated it into the docker binary itself as a subcommand so that’s v2
    • Sparkle-san 64 days ago
      > Rooting for it.

      No root necessary :)

  • dbacar 64 days ago
    To all those interested in podman, this book by Daniel Walsh is a gem. Highly recommended and it is free.

    https://developers.redhat.com/e-books/podman-action

    • 5d41402abc4b 64 days ago
      The font on that book is so awful. As someone with bad sight i have to strain my eyes a lot to read even a single sentence.
    • duckmysick 64 days ago
      Important to note, this book is from early 2023 and supports Podman version 4.1. It's missing newer features like quadlets.

      https://www.redhat.com/en/blog/quadlet-podman

      • msgilligan 64 days ago
        Yes. Definitely already needs a second edition. I would happily buy it.
  • vbezhenar 64 days ago
    Is CNCF new Apache foundation? Looks like everyone dumps their stuff there. Does not look promising. Am I missing something? Probably RedHat paid salary to podman developers, but who will pay salary to them now?
    • lysace 64 days ago
      In the same way as how the Kubernetes ecosystem is the new Enterprise Java ecosystem? Often even from the same companies as back in the late 90s/00s.

      Look: I'm probably ignorant, but from the outside the similarities seem striking.

      Please explain why I'm wrong. I'm humble on this one.

      • elzbardico 64 days ago
        Kubernetes is the new websphere. Yaml the new ANT.
    • gbraad 64 days ago
      The podman team and my team, working in the virtualization side (Podman Machine), will continue doing so
    • anticorporate 64 days ago
      I'm sure Red Hat will continue to pay Podman developers, just like they continue to pay developers for the other upstream projects that are hosted at CNCF (like Kubernetes).

      I'm we can all think of some projects "abandoned" to foundations through the years, but in general, I'd call getting core infrastructure out of the control of a single company and into a place with more transparent and democratic governance a good thing.

      • cryptos 64 days ago
        Maybe open source foundations should be more selective with the projects. I'm thinking of Oracle dumping OpenOffice, although it was obvious that LibreOffice is the way to go.
    • EdwardDiego 64 days ago
      Strimzi is CNCF, Strimzi still has a full time team of devs in RH.
    • nonameiguess 64 days ago
      I'm not sure why you think that. Plenty of CNCF projects, if not all of them, are still developed by the same corporate teams that originally developed them, even though ownership has been transferred. Cilium is still being developed by paid Isovalent employees. I'm pretty sure Kubernetes is still maintained mostly by Google employees. Longhorn and k3s are maintained by SUSE employees. This isn't Red Hat's first foray. They bought CoreOS, which is the company that originally developed etcd, one of the oldest CNCF projects that even predates Kubernetes, and most of its maintainers are still employees of either Red Hat or Google.
  • j1mc 64 days ago
    I think people are missing the contribution of bootc and composefs. This is a big part of what undergirds Red Hat's new 'image mode' means of deployment. They're using container-related tooling to deploy whole operating systems, and it's a large part of where they're headed.

    I write this to say, "This is not them dumping abandonware." To me, it's them putting these technologies under the supervision of a neutral third party to encourage adoption.

    • jauntywundrkind 64 days ago
      Composefs has a totally crucial feature that sold me immediately, which is that if two containers use the same file, the kernel can serve that file from the same page cache. This means you can hypothetically launch a lot of containers, and if they share some layers/base images, the memory usage can still be quite reasonable. Nice. https://github.com/containers/composefs?tab=readme-ov-file#b...
  • NewJazz 64 days ago
    Does podman support docker compose files well? Devs love them for local environments.
    • madspindel 64 days ago
      Try podman kube generate and podman kube play. Podman can generate a Kubernetes YAML, and then you can run it with kube play.

      I use it together with systemd in my home lab. It's Kubernetes for single node and without the bloat. I love it!

      https://www.redhat.com/en/blog/kubernetes-workloads-podman-s...

      • bjoli 64 days ago
        Being able to play around with kube files and then just shove them into a my-seevice.kube and execute them via systemd is really neat. The documentation is pretty OK as well: https://docs.podman.io/en/latest/markdown/podman-systemd.uni...

        The only downside is that some things are not yet supported in quadlets, and that things don't map 1 to 1 between quadlets and the command line.

    • jeppester 64 days ago
      I use podman with docker-compose files for my day-to-day work; spinning up databases and other service dependencies for locally running or containerized webapps.

      podman-compose never worked very well for me, so I'm running with the podman.socket systemd service and the standalone version of docker-compose. That is however working flawlessly.

      What I really like about podman (and which to be fair docker might have since catched up on) is that rootless containers work so well. Gone are the days where bind-mounting a project folder into a container would mess with your file permissions.

      In my experience podman also feels easier and less invasive to install, although I can't say if the latter is really the case.

      • ocular-rockular 64 days ago
        My only problems with Podman is the lack of up to date repos across systems, the fact that the latest raw binaries are managed by a maintainer out of the goodness of their heart, and that the VS Code extension ecosystem for managing pods is not integratable with the existing Docker stuff (and the replacement extensions are woefully underdeveloped).

        Otherwise it honestly is great and preferable over Docker.

        • jeppester 64 days ago
          I won't deny that the outdated repos was a pain in the past, but ever since ubuntu got to version 4 it's been working flawlessly for me.

          I think version 4 was where podman became a reliable tool, whereas I found it to be flaky and unreliable in previous versions.

          I don't use vs code extensions for managing my containers, so I can't say much about those, but I wonder if many of them won't work fine with an alias for docker and maybe the podman-socket running.

          • ocular-rockular 64 days ago
            Its broken with alias but what's this about the podman-socket? Do you know where I can take a look at that?
        • tristan957 64 days ago
          I think you can use the VSCode Docker extension if you enable the Podman socket.
    • avcxz 64 days ago
      For more information on compose files take a look at the Compose Spec [0], looks like podman compose supports the Compose Spec which Docker compose files use as well.

      [0] https://github.com/compose-spec/compose-spec?tab=readme-ov-f...

    • spockz 64 days ago
      I’ve been using it on my Fedora server because I make myself. I think all functionality and syntax is covered. However, the user feedback and TUI of docker-compose is way nicer (interactive at least). Also, podman compose does seem to recreate containers that do not need to be recreated in more cases than I have noticed docker compose do.
      • jeppester 64 days ago
        You can run the standalone version for docker-compose against podman. You just need to have the podman.socket systemd service running.
        • spockz 64 days ago
          Yes indeed. I have that on other systems as well. But I try to keep both around to notice these kind of differences. (I’m working on tooling that relies on docker compose files so I like to see how it behaves in different setups.)
    • lytedev 64 days ago
      I've been using podman-compose, yes.
    • dbacar 64 days ago
      Yes it doesm even with rootless. We are using it in prod.
  • gigatexal 64 days ago
    This is cool and all I just want to make sure podman and others are maintained and useful. I’m sure they will be it’s just that I use podman every day and depend on it.

    I could go back to docker but why?

  • greatgib 64 days ago
    Usually, when big orgs like that dump their projects to such a foundation (like Apache), it is that they are about to drop investing in support it soon.
  • philipwhiuk 64 days ago
    Hmm maybe worth switching from Docker Desktop to Podman Desktop...
  • xer0x 64 days ago
    What took them so long?
    • nijave 64 days ago
      My take was they sort of dug in said "Docker isn't made right for Linux, we're reinventing it"

      On Fedora w/ SELinux that led to quite a bit of compatibility issues for a while with lots of quirky things that didn't behave the same.

      I think their implementations have gotten pretty stable and improved in compatibility since then

      • 2OEH8eoCRo0 64 days ago
        That's my take as well. Red Hat's design choices fit into Linux much more neatly. Docker has always been rubbish with late cgroups v2 support, punching holes in my firewall, no rootless, etc.
    • tecleandor 64 days ago
      Waiting for IBM to buy them? (half joking)
  • RcouF1uZ4gsC 64 days ago
    Reading about Keycloak and how long it is taking to patch critical vulnerabilities, I wonder is CNCF becoming how Apache was - where abandoned open source software goes to die.
    • caniszczyk 64 days ago
      Last I checked, Keycloak has increased in activity since joining CNCF...

      https://keycloak.devstats.cncf.io/d/1/activity-repository-gr...

      CNCF has probably 20x the funding of the ASF and is a different organization that spends millions of dollars on security audits, events and more, you can read about it in our annual report: https://www.cncf.io/reports/cncf-annual-report-2023/

      Also we actively remove/prune projects that aren't active... we will probably archive ~10 this year https://www.cncf.io/project-metrics/

    • teepo 64 days ago
      I think that CNCF has better handle on abandonware, plus really good observably. https://devstats.cncf.io/
    • pphysch 64 days ago
      Hopefully the Keycloak thing will spur more competition. I looked at some alternatives and settled on Keycloak because it was "obviously" the mature and hardened solution.

      Well, clearly not.

      • pratio 64 days ago
        I've replaced keycloak with https://goauthentik.io/ 2 years on, no complaints
      • LilBytes 64 days ago
        Zitadel is worth a look, we're replacing Keycloak with it currently.
    • preisschild 64 days ago
      I think being a CNCF project is better than not being one. It gives it more visibility and structure and thus is less likely to be abandoned.

      But sure, unfortunately if not enough different companies and individiuals are maintaining stuff it gets abandoned.