Podman Compose 新手指南

yizhihongxing
作者:袁首京

原创文章,转载时请保留此声明,并给出原文连接。

技术人员多数又呆板又花心不长久。我知道你可能已经厌倦了 Docker,但是系统还没有复杂到需要高攀 K8S 的地步。那我建议您,有空的话可以约一下 Podman。

Podman 使用起来是足够简单的,直接把它当做改了名字的 Docker 就可以了。所以以下只介绍一下它的编排工具,也就是 podman-compose

简介

用 Docker 的时候,你知道它提供了一个编排工具,可以将容器的细节,例如名称、镜像、重启策略、卷、挂载点、端口、标签等等,在一个单一的文件中指定,这个文件通常命名为 docker-compose.yml

Podman 可以使用 podman-compose 达成类似的功能。简单的说,podman-compose 是使用 Podman 做为后端的一种 Compose Spec 实现,它的关注点主要是:

  • rootless 不需要 root 权限
  • daemon-less 没有守护进程

它最终的实现结果与 docker-compose.yml 文件的兼容度非常高,只存在一些细微的差异,比如说某些值需要使用引号括起来等。

安装

podman-compose 算是一个相对较新的工具,因此很多稳定或长期支持的 Linux 发行版,很可能还没有将它放在内置的软件源中。这种情况下,可以从 PyPI 安装:

sudo pip3 install podman-compose

Ubuntu 22.10 及以上或 Debian 12 及以上,则可以使用包管理器安装它:

sudo apt install podman-compose

Fedora 36 及以上,也可以直接安装:

sudo dnf install podman-compose

Arch Linux 用户:

sudo pacman -Syu podman-compose

验证安装

可以简单输出一下版本号,以验证是否安装正确:

podman-compose --version

输出类似下面:

$ podman-compose --version
['podman', '--version', '']
using podman version: 4.3.1
podman-composer version 1.0.3
podman --version
podman version 4.3.1
exit code: 0

编排

如前所述,podman-composedocker-compose 基本一致,所以不详细描述其文件结构了。直接看一个例子,比较容易理解,内容如下:

version: 3.7

services:
  reverse-proxy:
    image: docker.io/library/caddy:alpine
    container_name: caddy-vishwambhar
    command: caddy run --config /etc/caddy/Caddyfile
    restart: always
    ports:
      - "8080:80"
      - "8443:443"
    volumes:
      - /docker-volumes/caddy/Caddyfile:/etc/caddy/Caddyfile:Z
      - /docker-volumes/caddy/site:/srv:Z
      - /docker-volumes/caddy/caddy_data:/data:Z
      - /docker-volumes/caddy/caddy_config:/config:Z
      - /docker-volumes/caddy/ssl:/etc/ssl:Z
    labels:
      - io.containers.autoupdate=registry
      - pratham.container.category=proxy
    environment:
      - TZ=Asia/Kolkata
    depends_on:
      - gitea-web

  gitea-web:
    image: docker.io/gitea/gitea:latest
    container_name: gitea-govinda
    restart: always
    ports:
      - "8010:3000"
      - "8011:22"
    volumes:
      - /docker-volumes/gitea/web:/data:Z
      - /docker-volumes/gitea/ssh:/data/git/.ssh:Z
      - /etc/localtime:/etc/localtime:ro
    labels:
      - io.containers.autoupdate=registry
      - pratham.container.category=gitea
    environment:
      - RUN_MODE=prod
      - DISABLE_SSH=false
      - START_SSH_SERVER=true
      - SSH_PORT=22
      - SSH_LISTEN_PORT=22
      - ROOT_URL=https://git.mydomain.com
      - DOMAIN=git.mydomain.com
      - SSH_DOMAIN=git.mydomain.com
      - GITEA__database__DB_TYPE=postgres
      - GITEA__database__HOST=gitea-db:5432
      - GITEA__database__NAME=gitea
      - GITEA__database__USER=gitea
      - GITEA__database__PASSWD=/run/secrets/gitea_database_user_password
      - GITEA__service__DISABLE_REGISTRATION=true
      - TZ=Asia/Kolkata
    depends_on:
      - gitea-db
    secrets:
      - gitea_database_user_password

  gitea-db:
    image: docker.io/library/postgres:14-alpine
    container_name: gitea-chitragupta
    restart: always
    volumes:
      - /docker-volumes/gitea/database:/var/lib/postgresql/data:Z
    labels:
      - io.containers.autoupdate=registry
      - pratham.container.category=gitea
    environment:
      - POSTGRES_USER=gitea
      - POSTGRES_PASSWORD=/run/secrets/gitea_database_user_password
      - POSTGRES_DB=gitea
      - TZ=Asia/Kolkata
    secrets:
      - gitea_database_user_password

secrets:
gitea_database_user_password:
external: true

启动所有容器

可以简单使用 up 命令,启动编排文件中的所有容器与服务:

podman-compose up -d

上述命令背后将执行启动相关容器必须的所有操作,包括:

  • 拉取镜像
  • 使用指定选项(端口、卷、机密、网络等)创建容器
  • 按特定顺序启动容器(由约束定义,例如 depends_on)

-d 选项,随便一猜大概就能明白,是做为后台进程启动容器的意思。

容器启动并运行后,可以通过以下命令进行验证:

$ podman ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d7b7f91c03aa docker.io/library/caddy:alpine caddy run --confi... 4 hours ago Up 4 hours ago 0.0.0.0:8080->80/tcp, 0.0.0.0:8443->443/tcp caddy-vishwambhar
1cfcc6efc0d0 docker.io/library/postgres:14-alpine postgres 4 hours ago Up 4 hours ago gitea-chitragupta
531be3df06d0 docker.io/gitea/gitea:latest /bin/s6-svscan /e... 4 hours ago Up 4 hours ago 0.0.0.0:8010->3000/tcp, 0.0.0.0:8011->22/tcp gitea-govinda

停止容器与服务

既然启动是 up,那停止很明显就是 down 了。这俩单词我老早就认识,不知道你认识不认识?

podman-compose down

此外,您还可以设置个超时时间,容器到时可以安全地自行关闭:

podman-compose down -t TIMEOUT_IN_SECONDS
podman-compose down --timeout TIMEOUT_IN_SECONDS

注意,以上命令仅停止容器,并不会删除容器。

启动或停止特定服务

你应该注意到了,上面的配置文件定义了多个服务,比如其中之一是 gitea-db。如果单独启停它的话,可以象这样:

$ podman-comopse start gitea-db
$ podman-compose stop gitea-db
$ podman-compose restart gitea-db

其它

主要的命令其实就是上述这些了。剩余一两个可能用到的,简单描述一下。

假如想预先拉取一下相关镜像,可以使用命令:

podman-compose pull

另外,前述命令都假定编排文件的名字仍然叫 docker-compose.yml。肯定是可以换成其它名字的,比如 foo.yml,则使用时需要多加个参数,指定配置文件:

podman-compose -f foo.yml
podman-compose --file foo.yml

总之,使用起来还是相当简单愉快的。请君试之。

作者:袁首京

原创文章,转载时请保留此声明,并给出原文连接。

原文链接:https://www.cnblogs.com/rockety/p/17291605.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Podman Compose 新手指南 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • 如何将CentOS7升级至CentOS8(详细步骤)

    如何将CentOS7升级至CentOS8(详细步骤) 本文将带你详细了解如何将已安装CentOS7的系统升级至CentOS8版本。 1. 备份 在升级之前,强烈建议你对数据进行备份,以防数据丢失。 2. 安装epel-release包 在终端中执行下面的命令,安装epel-release包。 sudo yum install epel-release 3. …

    Linux 2023年5月14日
    00
  • Linux无法被远程登录;用户的关机, 重启,注销,新增用户,删除用户

    不能使用xshell连接到我的Linux服务器 通过再windows的cmd中ping了我的Linux地址,发现网络不通。 查看百度发现是因为网络没有选桥接模式,然后选完桥接模式告诉我: 然后发现没有虚拟网卡,原因是之前装过vm没有卸载干净,使用cclearn扫描注册表并修复,然后删除c盘中所有与Vmware有关的东西 重新启动电脑,重新安装vm,就解决了。…

    Linux 2023年4月13日
    00
  • 一些Centos Python 生产环境的部署命令(推荐)

    当我们在部署CentOS的Python生产环境时,一些命令是必不可少的。下面是一些有用的命令和示例: 更新系统并安装基本工具 首先需要更新系统并安装一些基本工具。可以使用以下命令: sudo yum update -y sudo yum install -y epel-release sudo yum install -y nano wget curl zi…

    Linux 2023年5月14日
    00
  • 小白教程! Linux服务器上JDK安装配置方法

    小白教程!Linux服务器上JDK安装配置方法 在Linux服务器上安装Java Development kit (JDK)是很重要的一步,因为Java是许多应用程序开发和运营所依赖的基本环境。本文将介绍在Linux平台上安装和配置JDK的方法。 步骤一:下载JDK 前往Oracle官网下载JDK:https://www.oracle.com/java/te…

    Linux 2023年5月14日
    00
  • Linux中mv命令的高级用法示例

    下面是详细讲解Linux中mv命令的高级用法示例的完整攻略。 mv命令简介 mv命令是Linux系统中用于移动或重命名文件和目录的命令,常用于文件管理和管理员工作中。使用mv命令还可以将文件或目录在不同的文件系统中进行迁移操作 mv命令基本用法 mv 命令的基本语法如下: mv [选项] 源文件或目录 目标文件或目录 例如,将路径为 /home/user1/…

    Linux 2023年5月14日
    00
  • Linux环境下用C++删除指定文件

    Linux环境下用C++删除指定文件 ”Talk is cheap, show me the code!“ #include <cstdio> #include <string> #include <sys/types.h> #include <sys/stat.h> #include <unistd.h…

    Linux 2023年4月13日
    00
  • vim的常用命令

    Vim的6种基本模式 1. 普通模式在普通模式中,用的编辑器命令,比如移动光标,删除文本等等。这也是Vim启动后的默认模式。这正好和许多新用户期待的操作方式相反(大多数编辑器默认模式为插入模式)。 2. 插入模式在这个模式中,大多数按键都会向文本缓冲中插入文本。大多数新用户希望文本编辑器编辑过程中一只保持这个模式。在插入模式中,可以按ESC键回到普通模式。 …

    Linux 2023年4月20日
    00
  • Linux下安装Oracle(CentOS-Oracle 12c)的方法

    下面是安装Oracle 12c的完整攻略: 1. 下载Oracle 12c安装文件 进入Oracle官网下载页面,下载Oracle 12c的压缩包。在本次教程中,我们使用的版本是:linuxamd64_12c_r1_database_1of2.zip和linuxamd64_12c_r1_database_2of2.zip。 2. 安装必要的依赖包 # 更新y…

    Linux 2023年5月14日
    00
合作推广
合作推广
分享本页
返回顶部