Podman complementa Buildah y Skopeo al ofrecer una experiencia similar a la línea de comandos de Docker:permite a los usuarios ejecutar contenedores independientes (no orquestados). Y Podman no requiere un daemon para ejecutar contenedores y pods, por lo que podemos despedirnos fácilmente de los grandes y gordos daemons. No hay demonios en segundo plano haciendo cosas, y esto significa que Podman se puede integrar en los servicios del sistema a través de systemd
.
En esta guía aprenderemos a instalar Podman en OpenSUSE Leap.
Publicaciones relacionadas
- Cómo instalar y usar Podman en Debian 11
- Cómo instalar y usar Podman en Rocky Linux/Alma Linux/Centos 8
- Cómo instalar y usar Podman en Fedora 34/35
- Cómo instalar y configurar docker en Rocky Linux/Centos 8
- Introducción a Docker Compose con ejemplos
- Docker como agente de compilación:ejecute compilaciones de Jenkins en Docker
Requisitos
Para seguir, asegúrese de tener lo siguiente:
- Un servidor/estación de trabajo OpenSUSE LEAP actualizado
- Acceso root o Usuario con acceso sudo
- Acceso a Internet
Tabla de contenido
- Asegurarse de que el servidor esté actualizado
- Instalando podman
- Ejemplos de línea de comando
- Contenedor persistente Runa postgres
- Administrar contenedores como servicios del sistema a través de systemd y Podman
1. Asegurarse de que el servidor esté actualizado
Use este comando para asegurarse de que nuestros paquetes de servidor estén actualizados
sudo zypper ref
sudo zypper update -y
Asegurémonos de que los paquetes comunes estén instalados
sudo zypper install -y vim
2. Instalando Podman
Podman está disponible en los repositorios predeterminados de OpenSUSE. Instálalo usando este comando:
sudo zypper install -y podman
Este comando instalará Podman y también sus dependencias.
Eso es todo. Ahora ya podemos jugar con Podman.
3. Ejemplos de línea de comandos
Exploremos la ejecución de OpenSUSE Leap Container usando podman.
En Docker usaríamos este comando para ejecutar un contenedor OpenSUSE Leap:
docker run -it opensuse/leap:15.3 sh
Esto fallará ya que no hay docker
comando en mi máquina OpenSUSE. Podemos reemplazar docker con podman:
podman run -it opensuse/leap:15.3 sh
Ejecutemos algunos comandos para confirmar que funciona como se esperaba:
~> podman run -it opensuse/leap:15.3 sh
Trying to pull registry.opensuse.org/opensuse/leap:15.3...
Getting image source signatures
Copying blob 7bc46307c67f done
Copying config 09d5e2cf44 done
Writing manifest to image destination
Storing signatures
sh-4.4# whoami
root
sh-4.4# cat /etc/os-release
NAME="openSUSE Leap"
VERSION="15.3"
ID="opensuse-leap"
ID_LIKE="suse opensuse"
VERSION_ID="15.3"
PRETTY_NAME="openSUSE Leap 15.3"
ANSI_COLOR="0;32"
CPE_NAME="cpe:/o:opensuse:leap:15.3"
BUG_REPORT_URL="https://bugs.opensuse.org"
HOME_URL="https://www.opensuse.org/"
sh-4.4#
Para verificar el estado del contenedor, use podman ps
comando
~> podman ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
eaa09408b382 registry.opensuse.org/opensuse/leap:15.3 sh 53 seconds ago Exited (0) 13 seconds ago priceless_curran
Para eliminar el contenedor, use podman rm
:
~> podman rm eaa09408b382
eaa09408b382ceb33a4696fed282e76df5130abf556b085ddc199eb30af54c8c
Para enumerar las imágenes:
~> podman images
REPOSITORY TAG IMAGE ID CREATED SIZE
registry.opensuse.org/opensuse/leap 15.3 09d5e2cf44af 2 weeks ago 111 MB
Podemos eliminar la imagen usando la imagen podman image rm
comando:
~> podman image rm opensuse/leap:15.3
Untagged: registry.opensuse.org/opensuse/leap:15.3
Deleted: 09d5e2cf44af39c62b803e65991d700d8300dc34d82ff03c9cf359b9e092177a
De lo anterior, podemos confirmar que el comando podman usa la misma sintaxis que docker
4. Ejecute un contenedor persistente de Postgres
A continuación, exploremos cómo podemos ejecutar un contenedor persistente. En este ejemplo, ejecutaremos un contenedor de Postgres 14 y montaremos los datos de Postgres en un volumen local para que pueda persistir en los reinicios. Dado que los contenedores son efímeros, los datos se perderán si no los guardamos en un volumen local.
Extraiga docker.io/library/postgres:14.0-alpine
imagen
~> podman image rm opensuse/leap:15.3
Untagged: registry.opensuse.org/opensuse/leap:15.3
Deleted: 09d5e2cf44af39c62b803e65991d700d8300dc34d82ff03c9cf359b9e092177a
[email protected]:~> podman pull docker.io/library/postgres:14.0-alpine
Trying to pull docker.io/library/postgres:14.0-alpine...
Getting image source signatures
Copying blob 82e9eb77798b done
Copying blob 5034a66b99e6 done
Copying blob 3da258773353 done
Copying blob c6b2245b2f36 done
Copying blob a0d0a0d46f8b done
Copying blob ccd761727716 done
Copying blob 028554d3b6cc done
Copying blob 2c7ee7bc69e8 done
Copying config 87440f4e7f done
Writing manifest to image destination
Storing signatures
87440f4e7f9e60607dc11a4f0590a1c69b3a1c075211df478e22b0c27fb263e6
Confirmar imágenes
~> podman images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/library/postgres 14.0-alpine 87440f4e7f9e 2 weeks ago 198 MB
Inspeccione la imagen con
$ podman inspect 87440f4e7f9e
Configuremos una carpeta que manejará los datos de Postgres una vez que iniciemos nuestro contenedor:
$ mkdir -p ~/apps/postgres/data
Ejecutarlo
podman run -d \
-p 5432:5432 \
-v ~/apps/postgres/data:/var/lib/postgresql/data \
-e POSTGRES_PASSWORD=Sup3rSecre7 \
-e POSTGRES_USER=citizix_user \
-e POSTGRES_DB=citizix_db \
docker.io/library/postgres:14.0-alpine
Esta es mi salida
~> podman run -d \
> -p 5432:5432 \
> -v ~/apps/postgres/data:/var/lib/postgresql/data \
> -e POSTGRES_PASSWORD=Sup3rSecre7 \
> -e POSTGRES_USER=citizix_user \
> -e POSTGRES_DB=citizix_db \
> docker.io/library/postgres:14.0-alpine
1607081ed241073e20e6186543c1882e977f2a91c9c061ccdd36a3e357051a44
Comprobar procesos:
~> podman ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
1607081ed241 docker.io/library/postgres:14.0-alpine postgres 11 seconds ago Up 10 seconds ago 0.0.0.0:5432->5432/tcp happy_jang
Confirme los registros del contenedor con esto. Puedes ver que está inicializando la base de datos
~> podman logs 1607081ed241 | head The files belonging to this database system will be owned by user "postgres". This user must also own the server process. The database cluster will be initialized with locale "en_US.utf8". The default database encoding has accordingly been set to "UTF8". The default text search configuration will be set to "english". Data page checksums are disabled. fixing permissions on existing directory /var/lib/postgresql/data ... ok
Conectémonos a la base de datos y hagamos algunas operaciones
$ podman exec -it 1607081ed241 /bin/bash
bash-5.1# psql -U citizix_user -d citizix_db;
psql (14.0)
Type "help" for help.
citizix_db=# select version();
version
--------------------------------------------------------------------------------------------------------------
PostgreSQL 14.0 on x86_64-pc-linux-musl, compiled by gcc (Alpine 10.3.1_git20210424) 10.3.1 20210424, 64-bit
(1 row)
citizix_db=#
A continuación, exploremos matar y eliminar el contenedor. Podemos usar podman kill
para detener el contenedor. Esto detendrá el contenedor, pero aún estará allí. Usa podman ps -a
Listar. Para eliminarlo por completo, podman rm -f
.
~> podman kill 1607081ed241
1607081ed241073e20e6186543c1882e977f2a91c9c061ccdd36a3e357051a44
~> podman ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
1607081ed241 docker.io/library/postgres:14.0-alpine postgres About a minute ago Exited (137) 15 seconds ago 0.0.0.0:5432->5432/tcp happy_jang
~> podman rm -f 1607081ed241
1607081ed241073e20e6186543c1882e977f2a91c9c061ccdd36a3e357051a44
5. Administrar contenedores como servicios del sistema a través de systemd y Podman
Podemos administrar contenedores podman a través de systemd. Vamos a crear un systemd
archivo de recursos para manejar el contenedor de postgres que acabamos de crear arriba.
Cree un archivo podman de postgres:
sudo vim /etc/systemd/system/postgres-podman.service
Añadir este contenido
[Unit]
Description=Custom Postgres Podman Container
After=network.target
[Service]
Type=simple
TimeoutStartSec=5m
ExecStartPre=-/usr/bin/podman rm -f postgrespodman
ExecStart=/usr/bin/podman run \
-p 5432:5432 \
-v /home/ec2-user/apps/postgres/data:/var/lib/postgresql/data \
-e POSTGRES_PASSWORD=Sup3rSecre7 \
-e POSTGRES_USER=citizix_user \
-e POSTGRES_DB=citizix_db \
docker.io/library/postgres:14.0-alpine
ExecReload=-/usr/bin/podman stop postgrespodman
ExecReload=-/usr/bin/podman rm postgrespodman
ExecStop=-/usr/bin/podman stop postgrespodman
Restart=always
RestartSec=30
[Install]
Entonces podemos recargar el systemd
catalogar e iniciar el servicio:
sudo systemctl daemon-reload
sudo systemctl start postgres-podman
Confirmar el estado del servicio
~> sudo systemctl status postgres-podman
● postgres-podman.service - Custom Postgres Podman Container
Loaded: loaded (/etc/systemd/system/postgres-podman.service; static)
Active: active (running) since Mon 2021-11-15 05:40:34 UTC; 12s ago
Process: 23658 ExecStartPre=/usr/bin/podman rm -f postgrespodman (code=exited, status=1/FAILURE)
Main PID: 23687 (podman)
Tasks: 12 (limit: 4587)
CGroup: /system.slice/postgres-podman.service
├─23687 /usr/bin/podman run -p 5432:5432 -v /home/ec2-user/apps/postgres/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=Sup3rSecre7 -e POSTG>
└─23828 /usr/bin/conmon --api-version 1 -c 8a18a63727ecd19d03710544e3e7ee9241e886d9fed45c1f25e29547ab61d600 -u 8a18a63727ecd19d03710544e3e7ee924>
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.477 UTC [1] LOG: starting PostgreSQL 14.0 on x86_64-pc-linux-musl, compiled by gcc (Alpine>
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.478 UTC [1] LOG: listening on IPv4 address "0.0.0.0", port 5432
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.478 UTC [1] LOG: listening on IPv6 address "::", port 5432
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.482 UTC [1] LOG: listening on Unix socket "/var/run/postgresql/.s.PGSQL.5432"
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.486 UTC [22] LOG: database system was interrupted; last known up at 2021-11-15 05:35:02 UTC
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.497 UTC [22] LOG: database system was not properly shut down; automatic recovery in progre>
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.499 UTC [22] LOG: redo starts at 0/16FAD98
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.499 UTC [22] LOG: invalid record length at 0/16FADD0: wanted 24, got 0
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.499 UTC [22] LOG: redo done at 0/16FAD98 system usage: CPU: user: 0.00 s, system: 0.00 s, >
Nov 15 05:40:35 ip-10-2-40-188 podman[23687]: 2021-11-15 05:40:35.509 UTC [1] LOG: database system is ready to accept connections
¡Acabamos de configurar un servicio de sistema personalizado basado en un contenedor administrado a través de Podman!
Conclusión
Logramos explorar cómo instalar Podman en nuestro servidor OpenSUSE Leap en esta guía.