podman 替代 docker ? centos Stream 10 已经弃用docker,开始用podman了!

👨‍🎓博主简介

  🏅CSDN博客专家
  🏅云计算领域优质创作者
  🏅华为云开发者社区专家博主
  🏅阿里云开发者社区专家博主
💊交流社区:运维交流社区 欢迎大家的加入!
🐋 希望大家多多支持,我们一起进步!😄
🎉如果文章对你有帮助的话,欢迎 点赞 👍🏻 评论 💬 收藏 ⭐️ 加关注+💗


文章目录

  • 一、什么是 podman?
  • 二、部署 podman
  • 三、podman 参数
    • 1、podman 镜像管理
    • 2、podman容器管理
    • 3、podman运行容器命令
  • 四、附加:修改podman 存储路径
    • 1、podman 中没有数据修改存储路径
    • 2、podman 中有数据迁移修改存储路径
  • 五、参考文章

一、什么是 podman?

在这里插入图片描述

  Podman 是一个开源项目,可在大多数 Linux 平台上使用,并位于GitHub 上。Podman 是一个无守护进程的容器引擎,用于在 Linux 系统上开发、管理和运行 Open Container Initiative (OCI) 容器和容器映像。Podman 提供了一个与 Docker 兼容的命令行前端,它可以简单地为 Docker cli ,alias docker=podman。Podman 还提供了一个套接字激活的 REST API 服务,以允许远程应用程序启动按需容器。此 REST API 还支持 Docker API,允许 docker-py 和 docker-compose 的用户与 Podman 作为服务进行交互。

  Podman 控制下的容器可以由 root 或非特权用户运行。Podman 使用libpod库管理整个容器生态系统,包括 pod、容器、容器映像和容器卷。Podman 专注于帮助您维护和修改 OCI 容器镜像的所有命令和功能,例如拉取和标记。它允许您在生产环境中创建、运行和维护从这些映像创建的容器。

  Podman 服务仅在 Linux 平台上运行,但 podman 远程 REST API 客户端存在于 Mac 和 Windows 平台上,并且可以通过 ssh 与运行在 Linux 机器或 VM 上的 Podman 服务进行通信。Mac 客户端。

二、部署 podman

正常 centos Stream 10里面是自带的有podman服务的;目前只知道 centos Stream8-10 系统会自带podman服务,其他系统没安装过,可自行查看podman --version

离线安装:podman 离线安装包


Podman 在 CentOS 8 和 Stream 的 AppStream 存储库中可用,可直接进行yum安装。

# 安装podman
yum -y install podman

# 查看podman版本号
podman --version

image-20240708155326314

这样就安装成功了;

  • 启动服务并配置开机自启
# 设置开机自启
systemctl enable podman
# 启动podman服务
systemctl start podman
# 重启podman服务
systemctl restart podman
# 停止podman服务
systemctl stop podman
# 查看podman服务状态()
systemctl status podman

三、podman 参数

podman常用参数和docker常用参数都是一样的;这里举例几个就行,具体的可以查看docker的命令参数:linux(centos)中部署docker(步骤超全,含带一些发展史和一些概念),查看后面的docker镜像管理、docker容器管理、docker运行容器命令

1、podman 镜像管理

#列出所有的镜像
[root@podman ~]# podman images
REPOSITORY   TAG       IMAGE ID   CREATED   SIZE
REPOSITORY:表示镜像的仓库源
TAG:镜像的标签
IMAGE ID:镜像ID
CREATED:镜像创建时间
SIZE:镜像大小
命令作用举例选项
podman search搜索镜像podman search busybox-f 按条件过滤
podman pull拉取镜像podman pull busybox:latest
podman push推送镜像到仓库podman push busybox:latest
podman tag为镜像修改或制作标签podman tag busybox:latest busybox:v1
podman rmi删除镜像podman rmi busybox:v1
podman save将镜像保存为tar包podman save -o centos7.tar centos:7-o 指定生成tar包名称
podman load将tar包保存的镜像导入podman load -i centos.tar-i 指定读取的tar包名称
podman import通过一个tar包创建镜像podman import centos-7.tar.gz centos7:v1
podman histroy查看镜像创建的历史podman history centos:7

podman中还提供了专门管理镜像的子命令podman image,用法与podman命令类似。

podman image 命令说明
podman images列出所有镜像
podman image ls列出所有镜像
podman image pull拉取镜像
podman image load导入镜像
podman image rm删除镜像
podman image inspect查看镜像的详细信息
podman image histroy查看镜像的创建记录
podman image push拉取镜像
podman image save导出镜像
podman image tag设置标签(修改版本)
podman image prune删除未使用的镜像
podman image buildpodmanfile构建镜像

2、podman容器管理

podman container命令说明举例选项
podman ps -a查看所有的容器
docekr ps查看所有的正在运行的容器
podman container ls查看运行的容器podman container ls-a/-q
podman container create创建容器但不运行podman container create nginx
podman container start启动容器podman start nginx
podman container stop关闭容器podman stop nginx
podman container restart重启容器podman restart nginx
podman container inspect查看容器的信息podman inspect nginx
podman container rm删除容器podman rm -f nginx-f强制删除
podman container rename给容器重命名podman rename nginx nginx2
podman container prune删除没有运行的容器
podman container pause暂停容器运行(挂起)
podman container unpause继续运行容器
podman container port列出端口映射podman port nginx2
podman container logs获取容器日志信息podman logs nginx2
podman container kill杀死正在运行的容器podman kill nginx2
podman container stats查看容器资源使用情况podman stats nginx2
podman container top查看容器的进程podman top nginx2
podman container diff对比容器文件变化 podman diff nginx nginx2
podman container cp容器与主机间文件复制podman cp a.txt nginx:/home/
podman container exec创建容器podman exec -itd–name nginx nginx:v1创建容器并运行
podman container export容器文件导出为tarpodman export nginx.tar nginx
podman container commit提交容器变化为新镜像podman commit nginx
podman container update更新容器配置podman update --restart=always nginx
podman container wait阻塞容器
podman container run运行一个podman容器podman run -itd --name nginx nginx:v1

3、podman运行容器命令

podman container run命令是根据指定镜像创建一个容器并启动运行。如果本地没有该镜像,则从podman仓库中拉去镜像。所以
podman container run = podman image pull + podman container create + podman container start
命令格式:podman container run [选项] 镜像名称|镜像ID [command]
常用选项:

参数解析
-d后台运行容器,返回容器ID,运行守护进程式容器
-i以交互模式运行容器,通常与 -t 同时使用;
-t为容器重新分配一个伪输入终端,通常与 -i 同时使用;
-P随机映射端口,容器内部端口随机映射为主机端口
-p指定端口映射, -p 主机端口:容器端口
- -expose指定暴露端口或端口范围
- -name指定生成容器的名称
-h指定容器的主机名称
-v映射容器外与容器内的目录
- -net指定podman网络模式(bridge/host/none/container)
- -restart指定是否开机自启
- -privileged使用该参数,container内的root拥有真正的root权限。
- -dns指定DNS服务器地址,默认与主机一致
-e设置环境变量
- -env-file从指定文件读取环境变量
1.运行交互式容器 
[root@podman ~]# podman container run -it --name='centos-1' centos:7 /bin/bash
[root@3ad7e1a5e55f /]#
直接退出,运行exit,容器会结束运行
[root@podman ~]# podman container ls -a
CONTAINER ID   IMAGE      COMMAND       CREATED          STATUS                     PORTS     NAMES
3ad7e1a5e55f   centos:7   "/bin/bash"   39 seconds ago   Exited (0) 6 seconds ago             centos-1
可以使用podman container start命令启动容器
[root@podman ~]# podman container start centos-1 
centos-1
[root@podman ~]# podman container ls -a
CONTAINER ID   IMAGE      COMMAND       CREATED              STATUS         PORTS     NAMES
3ad7e1a5e55f   centos:7   "/bin/bash"   About a minute ago   Up 2 seconds             centos-1
运行容器,不结束容器退出
[root@podman ~]# podman container run -it --name='centos-2' centos:7 /bin/bash
[root@764b82cb892f /]#(ctrl+pq)

2.启动守护进程式容器
[root@podman ~]# podman container run -d nginx:latest 
cef133be2d53c0d4921ceba34855e7dc250984191d10d3dfedf82195e9d85d3c
[root@podman ~]# podman ps -a
CONTAINER ID   IMAGE          COMMAND                  CREATED         STATUS         PORTS     NAMES
cef133be2d53   nginx:latest   "/podman-entrypoint.…"   6 seconds ago   Up 5 seconds   80/tcp    relaxed_lichterman
764b82cb892f   centos:7       "/bin/bash"              3 minutes ago   Up 3 minutes             centos-2
3ad7e1a5e55f   centos:7       "/bin/bash"              5 minutes ago   Up 4 minutes             centos-1

四、附加:修改podman 存储路径

podman和docker一样,默认都是存在与/var/lib/下的,一般镜像和容器都很大,可能会导致根磁盘空间占用过大,如果/根目录下空间满了,我们就要考虑给容器和镜像换位置;一般来说/根目录起初不会设置的很大,后续都会再加硬盘来扩容空间,所以这时候我们挂了一个磁盘,要把podman数据存储到比如/data/podman下,那么就如下操作就可以了;

1、podman 中没有数据修改存储路径

  • 打开 Podman 配置文件

没有就创建一个

sudo vim /etc/containers/storage.conf
  • 编辑存储配置:
[storage]
driver = "overlay"
runroot = "/data/podman/containers/run"
graphroot = "/data/podman/containers/storage"
  • 重新加载并启动podman服务
sudo systemctl daemon-reload
sudo systemctl restart podman
  • podman info 查看docker配置路径
sudo podman info

在这里插入图片描述

这样就修改成功了,如果不放心可以ls /data/podman/containers/storage/看看;

  • 查看 podman 服务运行状态
systemctl status podman

在这里插入图片描述

运行状态,那么就没问题了,接下来可以试试拉取镜像或者导入镜像

2、podman 中有数据迁移修改存储路径

注意:如果podman中已经存在了数据,那么就需要吧/var/lib/containers下的和podman相关的都挪到新的存储目录下然后在修改boltdb数据库里配置并重启数据库和podman服务方可生效;
切记:先移动或复制 --》 在修改配置文件 --》 在修改boltdb数据库 --》 在重启服务。

podman在数据库中可能会存储有运行配置,默认是在/var/lib/containers/storage/libpod/bolt_state.db中的,所以如果该数据库中存储了运行配置,则只修改了/etc/containers/storage.conf中的配置是不起作用的,podman会优先使用数据库中存储的配置,这点很坑。我们在修改了/etc/containers/storage.conf中的配置后,将在/var/lib/containers/复制到修改的路径下,重启之后,可以使用如下的命令来查看详细信息:

# 创建一个storage.conf文件
sudo vim /etc/containers/storage.conf

# 编辑配置文件
[storage]
driver = "overlay"
runroot = "/data/podman/containers/run"
graphroot = "/data/podman/containers/storage"

# 重启podman服务
sudo systemctl daemon-reload
sudo systemctl restart podman

# 查看podman服务状态
systemctl status podman

在这里插入图片描述

没有启动起来,报错了;

# 查看podman报错详细信息
sudo podman info --log-level=debug

在这里插入图片描述
所以如果bolt数据库存储了相关配置,那么无论怎么修改/etc/containers/storage.conf中的配置都会被重载而不起作用。
bolt_state.db又是一种小众的数据库,格式为bolt,目前BoltDB不支持直接修改和查看数据库内容,需要使用专门的bolt数据库工具才能查看和修改。
https://github.com/etcd-io/bbolt 页面罗列了不少bolt工具,笔者选用了boltdbweb这款Go写的Web工具来查看和修改。

在这里插入图片描述

打开runtime-config可以看到里面有graph-root就是podman的存储路径;

在这里插入图片描述

这里可以修改graph rootstatic dirvolume path配置,也可以直接删除掉,让podman直接使用/etc/containers/storage.conf中的配置。

注意,bolt_state.db文件非常重要,如果之前已经有很多容器,则里面存储了很多非常重要的信息,如果丢失,则之前的容器就废了,所以在操作前一定要备份。


修改数据库这边我没有弄,参考的: 改变podman的存储路径 - witton,总之,如果数据多的话先备份,而且并不建议更换。


五、参考文章

文件名文件连接
改变podman的存储路径 - wittonhttps://blog.csdn.net/witton/article/details/128497746

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/791705.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

记一次Ueditor上传Bypss

前言 前一段时间和小伙伴在某内网进行渗透测试,目标不给加白,只能进行硬刚了,队友fscan一把梭发现某资产疑似存在Ueditor组件,但初步测试是存在waf和杀软的,无法进行getshell,经过一番折腾最终getshell&am…

Python基础语法:运算符详解(算术运算符、比较运算符、逻辑运算符、赋值运算符)②

文章目录 Python中的运算符详解一、算术运算符二、比较运算符三、逻辑运算符四、赋值运算符五、综合示例结论 Python中的运算符详解 在Python编程中,运算符用于执行各种操作,例如算术计算、比较、逻辑判断和赋值。了解并掌握这些运算符的使用方法是编写…

【观成科技】Websocket协议代理隧道加密流量分析与检测

Websocket协议代理隧道加密流量简介 攻防场景下,Websocket协议常被用于代理隧道的搭建,攻击者企图通过Websocket协议来绕过网络限制,搭建一个低延迟、双向实时数据传输的隧道。当前,主流的支持Websocket通信代理的工具有&#xf…

物联网系统中市电电量计量方案(二)

上文我们主要介绍了电量计量中最重要的组成部分——电量计量芯片(如果没有阅读该文章的,可以点击这里)。本文会再为大家介绍电量计量的另外一个组成部分——电流互感器。 电流互感器的定义 电流互感器是一种可将一次侧大电流转换为二次侧小电…

AppStandby白名单机制

背景:原生机制中AppStandby机制的白名单是共享Doze白名单,即一旦设置doze白名单,也即AppStandby的白名单 需求:如何建立AppStandby自己的白名单 技术原理:可以使用setAppStandbyBucket接口实现 setAppStandbyBucket…

Java内存划分详解:从基础到进阶

Java内存划分详解:从基础到进阶 1. 程序计数器(Program Counter Register)2. Java虚拟机栈(Java Virtual Machine Stack)3. 堆(Heap)4. 方法区(Method Area)5. 运行时常量…

揭秘”大模型加速器”如何助力大模型应用

文章目录 一、大模型发展面临的问题二、“大模型加速器”助力突破困难2.1 现场效果展示2.1.1 大模型加速器——文档解析引擎2.2.2 图表数据提取 三、TextIn智能文档处理平台3.1 在线免费体验3.1.1 数学公式提取3.1.2 表格数据提取 四、acge文本向量化模型4.1 介绍4.2 技术创新4…

前端面试题40(浅谈MVVM双向数据绑定)

MVVM(Model-View-ViewModel)架构模式是一种用于简化用户界面(UI)开发的软件架构设计模式,尤其在现代前端开发中非常流行,例如在使用Angular、React、Vue.js等框架时。MVVM模式源于经典的MVC(Mod…

网络协议(TCP三次握手,四次断开详解)

TCP的详细过程: TCP(传输控制协议)的三次握手和四次断开是其建立连接和终止连接的重要过程,以下是详细解释: 三次握手: 1. 第一次握手:客户端向服务器发送一个 SYN(同步&#x…

【python】QWidget父子关系,控件显示优先级原理剖析与应用实战演练

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…

51单片机嵌入式开发:8、 STC89C52RC 操作LCD1602原理

STC89C52RC 操作LCD1602原理 1 LCD1602概述1.1 LCD1602介绍1.2 LCD1602引脚说明1.3 LCD1602指令介绍 2 LCD1602外围电路2.1 LCD1602接线方法2.2 LCD1602电路原理 3 LCD1602软件操作3.1 LCD1602显示3.2 LCD1602 protues仿真 4 总结 1 LCD1602概述 1.1 LCD1602介绍 LCD1602是一种…

室内精准定位哪个产品抗干扰能力强?可以用于哪些方面?

室内精准定位产品其实有很多,其实它是安装在室内接收型号的一个基站,并且范围有一定的限制,而被定位的人员需要携带定位产品,那么通过室内基站收集到的信息,将会通过专业的系统处理后呈现在相应的设备上,比…

elementui实现复杂表单的实践

简介 文章主要讲述在vue3项目中使用elementui框架实现复杂表单的方式。表单中涉及动态组件的生成、文件上传和富文本编辑器的使用,只会将在实现过程中较复杂的部分进行分享,然后提供一份完整的前端代码。 表单效果演示 基础信息 spu属性 sku详情 关键…

【机器学习】初学者经典案例(随记)

🎈边走、边悟🎈迟早会好 一、概念 机器学习是一种利用数据来改进模型性能的计算方法,属于人工智能的一个分支。它旨在让计算机系统通过经验自动改进,而不需要明确编程。 类型 监督学习:使用带标签的数据进行训练&…

【游戏客户端】大话slg玩法架构(二)背景地图

【游戏客户端】大话slg玩法架构(二)背景地图 大家好,我是Lampard家杰~~ 今天我们继续给大家分享SLG玩法的实现架构,关于SLG玩法的介绍可以参考这篇上一篇文章:【游戏客户端】制作率土之滨Like玩法 PS:和之前…

仕考网:公务员如何备考申论

在备战公务员考试的申论部分时,掌握一定的技巧,遵循特定的步骤是至关重要的。以下是一些备考策略,希望能帮助到大家: 1. 掌握考试大纲和命题趋势 在考试大纲中明确了题目的类型和可能涉及的主题范围,考生可以聚焦到关…

批量提取Word文档中表格内容

1 背景 有一个word文件,其中包含多个格式一致的表格(如下图),需要将其内容进行提取,填写到excel中 2 实现代码 ## 导入工具包 from docx import Document import pandas as pd## 读取 Word 文件 document Document(…

MySQL实现数据备份的方式可以基于哪几种?

MySQL 数据库实现数据备份的方式主要有以下几种: 物理备份 (Physical Backup): 冷备份 (Cold Backup):在数据库关闭的情况下,直接复制数据库文件(数据文件、日志文件等)。这种方式操作简单,但是…

UML类图的建立过程

1. 概念层类图 概念层的类图描述的是现实世界中对问题领域的概念理解,类图中表达的类与现实世界的问题领域中的实际事物有着明显的对应关系,类之间的关系也与问题领域中实际事物之间的关系有着明显的对应关系。在概念层类图阶段很少考虑或者几乎不需要考…

应急响应-ELK日志分析系统

🎼个人主页:金灰 😎作者简介:一名简单的大一学生;易编橙终身成长社群的嘉宾.✨ 专注网络空间安全服务,期待与您的交流分享~ 感谢您的点赞、关注、评论、收藏、是对我最大的认可和支持!❤️ 🍊易编橙终身成长社群&#…