Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stuttgart-things/install-configure-podman
installs and configures podman, buildah and skopeo on linux
https://github.com/stuttgart-things/install-configure-podman
containerization linux podman skopeo
Last synced: 28 days ago
JSON representation
installs and configures podman, buildah and skopeo on linux
- Host: GitHub
- URL: https://github.com/stuttgart-things/install-configure-podman
- Owner: stuttgart-things
- License: apache-2.0
- Created: 2023-03-06T16:42:19.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-13T11:22:05.000Z (7 months ago)
- Last Synced: 2024-11-05T23:06:26.593Z (3 months ago)
- Topics: containerization, linux, podman, skopeo
- Language: Jinja
- Homepage:
- Size: 60.5 KB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
stuttgart-things/install-configure-podman
=========================================installs and configures podman, buildah and skopeo on various linux os
Variables
* `install_tools` - Set this on False if you don't want buildah and skopeo to be installed (default: true)
* `buildah_version` - Set the wanted buildah version
* `skopeo_version` - Set the wanted skopeo version
* `configure_docker_registry_mirror` - Set this on true if you want docker registry mirrors to be created (default: false)
* `ubuntu_version` - If you don't use a different OS, set your Ubuntu versionROLE INSTALLATION
copy and paste the following into your terminal:
```bash
cat < /tmp/requirements.yaml
roles:
- src: https://github.com/stuttgart-things/install-configure-podman.git
scm: git
- src: https://github.com/stuttgart-things/install-requirements.git
scm: gitcollections:
- name: community.general
version: 8.6.0
- name: containers.podman
version: 1.13.0
EOFansible-galaxy install -r /tmp/requirements.yaml --force
ansible-galaxy collection install -r /tmp/requirements.yaml --forcerm -rf /tmp/requirements.yaml
```EXAMPLE INVENTORY
```bash
cat < inventory
[appserver]
1.2.3.4 ansible_user=sthings
EOF
```EXAMPLE PLAYBOOK
copy and paste the following (on any place of the filesystem of the ansible host) into your terminal:
```yaml
cat < install-configure-podman.yaml
---
- hosts: "{{ target_host | default('all') }}"
become: true
roles:
- role: install-configure-podman
EOF
```EXAMPLE EXECUTION
```bash
ansible-playbook -i inventory install-configure-podman.yaml -vv
```EXAMPLE USE-CASES BUILDAH AND PODMAN
```bash
# Check buildah version
buildah version
```
```bash
# Pull Image
buildah pull alpine
```
```bash
# Create Dockerfile
# Podman and Buildah default to Containerfile and will fall back to Dockerfile.
cat < Dockerfile
FROM ubuntu:18.04
RUN echo 'Hello, World!' > /test.txt
EOF
```
```bash
# Build Image
buildah build -t hello-world -f ./Dockerfile .
```
```bash
# Run Podman (--rm = delete container after running)
podman run -it hello-world cat /test.txt
```
```bash
# Show Container name and ID
podman ps
```
```bash
# Stop Container
podman stop {container-name-or-id}
```
```bash
# Copy file from local to container
buildah copy container-name ./example.sh /usr/bin
```
```bash
# Configure Image to run commands
buildah config --cmd /usr/bin/example.sh container-name
```
```bash
# Buildah unmount container
buildah config --cmd /usr/bin/example.sh container-name
```
```bash
# Buildah commit image
buildah commit container-name new-image-name
```
```bash
# Show Image
buildah images
```EXAMPLE USE-CASES PODMAN PLAY KUBE
The Podman Play Kube Option is not available for remote clients, including Mac and Windows (excluding WSL2) machines, yet.
Currently supported Kinds in Kubernetes:
* `Pod`
* `Deployment`
* `PersistentVolumeClaim`
* `ConfigMap````yaml
# Create Pod
cat < example-pod.yaml
---
apiVersion: v1
kind: Pod
metadata:
name: hello-world-pod-2
labels:
app: hello-world
spec:
containers:
- name: hello-world-sh
image: busybox
command: ['sh', '-c', 'while true; do echo "Hello World"; sleep 2; done']
- name: hello-world-http
image: busybox
command: ['sh','-c', 'echo "hello world" > index.html && /bin/httpd -p 9000 -f']
ports:
- containerPort: 9000
protocol: TCPEOF
```### Service
SERVICE TO EXPOSE POD TO PUBLIC
```yaml
# Create Service to expose pod to public
cat < example-service.yaml
---
kind: Service
apiVersion: v1
metadata:
name: hello-world-svc
spec:
type: NodePort
ports:
- port: 80
targetPort: 9000
selector:
app: hello-worldEOF
```##
```bash
# Create pod
podman play kube example-pod.yaml
```
```bash
# Tear down pod
podman play kube --down example-pod.yaml
```EXAMPLE USE-CASE PODMAN GENERATE KUBE
### GENERATE KUBE YAML
Note: When using volumes and generating a Kubernetes YAML for an unprivileged and rootless podman container on an SELinux enabled system, one of the following options must be completed:
* `Add the “privileged: true” option to the pod spec`
* `Add type: spc_t under the securityContext seLinuxOptions in the pod spec`
* `Relabel the volume via the CLI command chcon -t container_file_t -R /directory````bash
# Generate yaml from Kubernetes Ressource
podman generate kube example-pod-name
```EXAMPLE USE-CASES SKOPEO
```bash
# Login to private registry with authentication
skopeo login --username USER myregistrydomain.com:5000
# Logout of private registry
skopeo logout myregistrydomain.com:5000
```
```bash
# Show properties of docker.io/library/alpine
skopeo inspect docker://docker.io/library/alpine
```
```bash
# Syncing registries
skopeo sync --src docker --dest dir registry.example.com/busybox /media/usb
```
```bash
# Copy Image
skopeo copy oci:busybox_ocilayout:latest dir:existingemptydirectory
# Copy Image with creds
skopeo copy --src-creds=testuser:testpassword docker://myregistrydomain.com:5000/private oci:local_oci_image
```## License
LICENSECopyright 2020 patrick hermann.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.Role history
----------------
| date | who | changelog |
|---|---|---|
|2024-30-04 | Andre Ebert | Added Buildah and Skopeo install, added Ansible- and Yamllint with skip rules and collection release workflow
|2020-10-10 | Patrick Hermann | Updated for using ansible collections, added Debian support; defined stable version
|2020-04-03 | Patrick Hermann | intial commit for this role on codehubAuthor Information
------------------```yaml
Andre Ebert ([email protected]); 04/2024Patrick Hermann ([email protected]); Stuttgart-Things; 04/2020
```