Building Kubernetes-style pods with Podman
data:image/s3,"s3://crabby-images/08733/08733dfcb0c2f2c9e7619cd6846f964c98bc0b82" alt="Building Kubernetes-style pods with Podman"
In a recent piece, I discussed Podman, a wonderful Red Hat-powered project that provides a container alternative supported by Kubernetes and a replacement for Docker, read more at the following link.
data:image/s3,"s3://crabby-images/1619b/1619b09bd3e33465447fa23b3d5a9465d3de08bd" alt=""
The podman build commands is entirely compatible with OCI Image Spec, and the instructions are too near to Kubernetes-style and Docker-CLI. However, there are two ways to describe containers:
- podman-compose, an implementation of Compose Spec and alternative to docker-compose maintened by community
- podman play kube, an official implementation to create containers, pods or volumes based on Kubernetes YAML.
This time, we'll create pods with yaml (play-kube) syntax. This method provides the following advantages:
- Instead of shell-script, describe your pods in a yaml file.
- You can generate Kubernetes yaml after you've created and ran pods;
Running a basic web pod
My favorite container image to test is traefik-whoami, which is a basic web application with rich information such as hostname, IP and HTTP request data.
This is a yaml file containing a whoami container written in Kubernetes yaml syntax.
- kind: defines file format;
- metadata: It is useful to define pod names, labels, and data to identify pods;
- spec: define containers, how they operate, and their policies;
- spec.containers: a list of containers with their names, utilized images, exposed ports, environment variables, resources, and other specifications;
Now execute the following command to start a pod.
This pod will listen on port 8080, so feel free to use your terminal's with curl or web browser.
data:image/s3,"s3://crabby-images/5bbb6/5bbb6e8dd2c35c3947e1dc39453cedb5ebde11ad" alt=""
As previously said, we can produce Kubernetes yaml by running the following command.
This is the Kubernetes pod yaml file that was generated, save it as /tmp/pod.yaml.
Unfortunately, no update command exists, such as kube apply -f whoami.yaml, which we used in Kubernetes. To down pods, use the following command:
If you're looking for a practical introduction to Kubernetes, go to the following link first:
data:image/s3,"s3://crabby-images/5ca9d/5ca9d8e3b9231fd1d29d3fb50ac969c5ce46e4f6" alt=""
It's time to run our generated Kubernetes yaml, run the following command:
Remember to down 🔻 pods before running the following command and save the created pod file yaml.
The pod will be deployed and started at port 8080 by Kubernetes this time. So you can double-check connection.
data:image/s3,"s3://crabby-images/6d4da/6d4da241be45bfec65d62e6a32e40a34402474d0" alt=""
Now we'll take pods down again and construct something new with multiple pods, run following command:
Multiple database pods
This time we will run multiple database pods with Adminer to test connectivity between pods.
Take a look at the following yaml file, which contains three pods: PostgreSQL, MariaDB, and Adminer:
Let's take a quick look at the Kubernetes yaml syntax.
- kind: defines file format;
- metadata: It is useful to define pod names, labels, and data to identify pods;
- spec: define containers, how they operate, and their policies;
- spec.containers: a list of containers with their names, utilized images, exposed ports, environment variables, resources, and other specifications;
- containers.resources: used to set a resource restriction such as memory RAM and CPU
- volumes: define persistent storage data to be utilized by pods;
- volumeMounts: provide the directory that will be mapped to the persistent storage;
The only pod that will expose a port will be Adminer at port 8080, enter the following command to run pods:
💡 Remember to name the file adminer.yaml
Now that the Adminer pod is up and running at port 8080, you may login to any database using the super secret credentials:
Database | Host | Username | Password |
---|---|---|---|
mariadb | databases-mariadb | foo | bar |
postgresql | databases-postgresql | foo | bar |
Now it's time to test connection.
data:image/s3,"s3://crabby-images/05684/05684022efc5e5c985cddee40996dac6caa74bfa" alt=""
data:image/s3,"s3://crabby-images/8b42d/8b42d9fa1ac65bb635687be287f46617542a9892" alt=""
You may produce and run yaml for your homework by using the commands kube generate and kubectl apply:
When podman generates a Kubernetes YAML, it is expected to have PersistentVolumeClaim created, thus create a file named databases-pvc.yaml.
Now we can execute this script on a Kubernetes-powered test pod (postgres, mariadb, and adminer).
Kubernetes uses a single DNS for each, rather than a hostname alias for each container (databases-mariadb, databases-postgresql) such podman does, you must use host "databases" to access PostgreSQL or MariaDB, wonderful 🥲.
That's all, folks.
If you prefer, you can clone the repository
With this work, we learnt how to use podman to describe pods and build Kubernetes YAML.
Podman is constantly updated; some features may not be completely compatible with Kubernetes, and you might face some unexpected instructions when generating your YAML; however, it is important to note that Podman is a hand on the wheel, allowing you to test your pods locally and save time writing deployments.
Have a wonderful weekend, and God bless you 🙏🏿 and keep your kernel 🧠 updated
Time for feedback!