Skip to content

Introduction

Podman is a Docker-compatible alternative container runtime that, unlike Docker, is included in the Rocky Linux repositories and can run containers as a systemd service.

Install Podman

Use the dnf utility to install Podman:

dnf install podman

Adding a container

Let us run a Nextcloud self-hosted cloud platform as an example:

podman run -d -p 8080:80 nextcloud

You will receive a prompt to select the container registry from which to download. In our example, we will use docker.io/library/nextcloud:latest.

Once you have downloaded the Nextcloud container, it will run.

Enter ip_address:8080 in your web browser (assuming you opened the port in firewalld) and set up Nextcloud:

Nextcloud in container

Running containers as systemd services

Using quadlet

Since 4.4, Podman ships with Quadlet, a systemd generator that can generate unit files for rootless and rootful systemd services.

Quadlet files for rootful services can be placed in

  • /etc/containers/systemd/
  • /usr/share/containers/systemd/

while rootless files can be placed in either of

  • $XDG_CONFIG_HOME/containers/systemd/ or ~/.config/containers/systemd/
  • /etc/containers/systemd/users/$(UID)
  • /etc/containers/systemd/users/

While single containers, pods, images, networks, volumes, and kube files are supported, let's focus on our Nextcloud example. Create a new file ~/.config/containers/systemd/nextcloud.container with the following content:

[Container]
Image=nextcloud
PublishPort=8080:80

A lot of other options are available.

To run the generator and let systemd know that there is a new service run:

systemctl --user daemon-reload

To now run your service run:

systemctl --user start nextcloud.service

Note

If you created a file in one of the directories for rootful services, omit the --user flag.

To automatically run the container upon system start or user login, you can add another section to your nextcloud.container file:

[Install]
WantedBy=default.target

As the generated service files are considered transient, they cannot be enabled by systemd. To mitigate this, the generator manually applies installs during generation. This effectively also enables those services files.

Other file types are supported: pod, volume, network, image, and kube. Pods, for instance, can be used to group containers – the generated systemd services and their dependencies (create the pod before the containers) are automatically managed by systemd.

Using podman generate systemd

Podman additionally provides the generate systemd subcommand. It can be used to generate systemd service files.

Warning

generate systemd is now deprecated and will not receive further features. The usage of Quadlet is recommended.

Let us now do it with Nextcloud. Run:

podman ps

You will get a list of running containers:

04f7553f431a  docker.io/library/nextcloud:latest  apache2-foregroun...  5 minutes ago  Up 5 minutes  0.0.0.0:8080->80/tcp  compassionate_meninsky

As seen above, our container's name is compassionate_meninsky.

To make a systemd service for the Nextcloud container and enable it on reboot, run the following:

podman generate systemd --name compassionate_meninsky > /usr/lib/systemd/system/nextcloud.service
systemctl enable nextcloud

Replace compassionate_meninsky with your container's assigned name.

When your system reboots, Nextcloud will restart in Podman.

Author: Neel Chauhan

Contributors: Steven Spencer, Ganna Zhyrnova, Christian Steinert