podman的部署和應用

来源:https://www.cnblogs.com/tushanbu/archive/2022/08/15/16588086.html
-Advertisement-
Play Games

podman的部署和應用 podman官方網站(https://podman.io/) 什麼是podman Podman是一個無守護進程的容器引擎,用於在Linux系統上開發、管理和運行OCI容器。容器可以作為根運行,也可以以無根模式運行。簡單地說:別名docker=podman 它是一款集合了命令 ...


podman的部署和應用


目錄

podman官方網站(https://podman.io/)

什麼是Podman

Podman是一個無守護進程的容器引擎,用於在Linux系統上開發、管理和運行OCI容器。容器可以作為根運行,也可以以無根模式運行。簡單地說:別名docker=podman

  1. 它是一款集合了命令集的工具,設計初衷是為了處理容器化進程的不同任務,可以作為一個模塊化框架工作。它的工具集包括:
    Podman:Pod和容器鏡像管理器
    Buildah:容器鏡像生成器
    Skopeo:容器鏡像檢查管理器
    Runc:容器運行器和特性構建器,並傳遞給Podman和Buildah
    Crun:可選運行時,為Rootless容器提供更大的靈活性、控制和安全性

  2. 這些工具還可以與任何OCI相容的容器引擎(如Docker)一起工作,使其易於轉換到Podman或與現有的Docker安裝一起使用。Kubernetes可以使用Podman嗎?答案是:是的。事實上,Kubernetes和Podman在某些方面是相似的。

  3. Podman是一個無守護進程的開源Linux本地工具,旨在使用開放容器倡議(open Containers Initiative, OCI)容器和容器映像輕鬆查找、運行、構建、共用和部署應用程式。Podman提供了一個命令行介面(CLI),任何使用過Docker容器引擎的人都很熟悉。大多數用戶可以簡單地將Docker別名為Podman(別名Docker = Podman),沒有任何問題。與其他常見的容器引擎(Docker, CRI-O, containerd)類似,Podman依賴於一個相容OCI的容器運行時(runc, crun, runv等)與操作系統介面,並創建運行的容器。這使得Podman創建的運行中的容器與其他任何普通容器引擎創建的容器幾乎沒有區別

  4. Podman控制下的容器可以由root或非特權用戶運行。Podman使用libpod庫管理整個容器生態系統,包括pods、容器、容器映像和容器捲。Podman擅長於幫助維護和修改OCI容器映像的所有命令和功能,例如拉取和標記。它允許您在生產環境中創建、運行和維護這些容器和容器映像。
    有一個用於管理容器的RESTFul API。我們還有一個可以與RESTFul服務交互的遠程Podman客戶端。我們目前支持Linux、Mac和Windows上的客戶端。rest式服務僅支持Linux操作系統。

什麼是Docker

  1. Docker是標準的容器管理技術。Docker在行業中舉足輕重,以至於大多數人一想到容器,就會想到Docker。

  2. Docker是容器編排世界的一把瑞士軍刀,在其他替代方案出現之前就已經提供了諸多特性。隨著容器管理複雜度的增加,它也必須成長為一個獨立的、自給自足的工具,以便能提供開發人員的所有需求。

  3. Docker也在很短的時間內,就成為All-in-one解決方案的關鍵工具之一。其中一款就是Docker Swarm,這是一款由Docker原生的,可以讓你組建群集和調度Docker引擎,以及用來創建和管理容器群的解決方案。

  4. Docker的諸多輔助工具處理所有與容器編排相關的任務,從負載均衡到網路,使其成為行業的首選,不光是作為行業技術參考。

  5. 儘管Docker是一個強大的系統,但這種自給自足的模式也有它的缺點。雖然可以在開發的所有階段創建和運行容器,但其他工具在與Docker集成交互時或多或少存在些困難。

  6. 近年來,隨著許多其他用於特定任務的專用工具的出現,Docker成為許多開發人員的起點,隨之,他們將一些任務分配給其他更輕量級的平臺和工具。

Podman的使用與Docker有什麼區別


Podman和Docker有許多共同的特性,但也有一些根本的區別。技術不分好壞,只是著重於哪個更適用於某些特定的場景。

Podman與Linux內核交互,通過runC容器運行時進程而不是Daemon來管理容器。Buildah實用程式用於替代Docker build作為容器鏡像構建工具,Docker push被Skopeo替代,用於在註冊表和容器引擎之間移動容器鏡像。

架構
Docker使用守護進程,一個正在後臺運行的程式,來創建鏡像和運行容器。Podman是無守護進程的架構,這意味著它可以在啟動容器的用戶下運行容器。Docker有一個由守護進程引導的客戶端——伺服器邏輯架構;但Podman不需要此類守護進程。

Root特權
由於Podman沒有守護進程來管理其活動,也無需為其容器分配Root特權。Docker最近在其守護進程配置中添加了Rootless模式,但Podman首先使用了這種方法,並將其作為基本特性進行了推廣。原因如下。

安全
Podman比Docker安全嗎?Podman允許容器使用Rootless特權。Rootless容器被認為比Root特權的容器更安全。在Docker中,守護進程擁有Root許可權,這使得它們易成為攻擊者的首選入侵點。
Podman中的容器預設情況下不具有Root訪問許可權,這在Root級別和Rootless級別之間添加了一個自然屏障,提高了安全性。不過,Podman可以同時運行Root容器和Rootless容器。

Systemd
如果沒有守護進程,Podman需要另一個工具來管理服務並支持後臺運行的容器。Systemd為現有容器創建控制單元或用來生成新容器。Systemd還可以與Podman集成,允許它在預設情況下運行啟用了Systemd的容器,從而無需進行任何修改。
通過使用Systemd,供應商可以將他們的應用程式封裝為容器用來安裝、運行和管理,因為現在大多數應用程式都是通過這種方式打包和交付的。

構建鏡像
作為一款自給自足的工具,Docker可以自己構建容器鏡像。Podman則需要另一種名為Buildah的工具的輔助,該工具充分體現了它的特殊性:它是為構建鏡像而設計的,而不是為構建容器而生。

Docker Swarm
Podman不支持Docker Swarm,這可能會在某些項目中被刨除在外,因為使用Docker Swarm命令會產生一個錯誤。然而,Podman最近增加了對Docker Compose的支持,使其與Swarm相容,從而剋服了這個限制。當然,Docker由於其原生的特性,與Swarm當然融合得很好。

All in one vs 模塊化
也許這就是這兩種技術的關鍵區別:Docker是一個獨立的、強大的工具,在整個迴圈中處理所有的容器化任務,有優點也有缺點。Podman採用模塊化的方法,依靠專門的工具來完成特定的任務。

Podman vs Docker:他們能合作嗎?
作為最好的、最易應用於Docker的替代方案——用戶可以將Docker別名設置為Podman(alias docker=podman),且不會出現任何問題,正如上面圖中中所示——Podman是一個非常強大的容器化任務工具。

Podman會是Docker的替代品嗎?
如果你要從頭開始一個項目,Podman可以是一個首要的容器化技術選項。如果項目正在進行,並且已經在使用Docker,這還需要具體情況具體分析,實際情況並不一定值得去改。而且作為一款Linux原生的應用,它要求相關開發人員具備Linux的相關技能。
開發人員可以在開發階段依賴Docker,然後在運行時環境中將項目推向Podman,從而結合使用這兩種工具,並受益於Podman所提供的更安全性。由於它們都是OCI相容的,因此,相容性不是個問題。

Docker和Podman能共存嗎?
是的,而且會很好。許多開發人員一直在合用Docker和Podman來創建更安全、更高效、更敏捷的框架。它們有很多共同之處,無論是從Docker到Podman的轉變,亦或是二者合併使用,都可以做到無縫銜接。

部署Podman

[root@localhost ~]# ls /etc/yum.repos.d/
CentOS-Base.repo     
//此處我配置的是阿裡源,可以直接去官網上面找
[root@localhost ~]# dnf list|grep podman
Failed to set locale, defaulting to C.UTF-8
cockpit-podman.noarch                                  33-1.module_el8.5.0+890+6b136101                       AppStream 
pcp-pmda-podman.x86_64                                 5.3.1-5.el8                                            AppStream 
podman.x86_64                                          3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
podman-catatonit.x86_64                                3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
podman-docker.noarch                                   3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
podman-gvproxy.x86_64                                  3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
podman-plugins.x86_64                                  3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
podman-remote.x86_64                                   3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
podman-tests.x86_64                                    3.3.1-9.module_el8.5.0+988+b1f0b741                    AppStream 
python3-podman.noarch                                  3.2.0-2.module_el8.5.0+890+6b136101                    AppStream 
//列出系統中的podman,我們需要的是podman.x86_64,podman-docker.noarch,可以直接安裝podman-docker.noarch
[root@localhost ~]# which podman
/usr/bin/which: no podman in (/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin)
//查看系統中是否有podman命令
[root@localhost ~]# dnf -y install podman-docker
//安裝podman
[root@localhost ~]# which podman
/usr/bin/podman     //現在可以查看到有podman命令
[root@localhost ~]# which docker 
/usr/bin/docker     //雖然顯示有docker命令但是是沒有的
[root@localhost ~]# dnf list|grep docker    //可以查看到沒有安裝docker
Failed to set locale, defaulting to C.UTF-8
podman-docker.noarch                                   3.3.1-9.module_el8.5.0+988+b1f0b741                    @AppStream
pcp-pmda-docker.x86_64                                 5.3.1-5.el8                                            AppStream 
[root@localhost ~]# ll /usr/bin/docker 
-rwxr-xr-x. 1 root root 163 Nov 10  2021 /usr/bin/docker
//查看docker的程式
[root@localhost ~]# ll /usr/bin/podman 
-rwxr-xr-x. 1 root root 49688376 Nov 10  2021 /usr/bin/podman
//查看podman的程式
[root@localhost ~]# file /usr/bin/docker 
/usr/bin/docker: POSIX shell script, ASCII text executable
//可以查看到docker是一個腳本
[root@localhost ~]# file /usr/bin/podman
/usr/bin/podman: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 3.2.0, BuildID[sha1]=53954cc47243d7854d8d1bf5d09e919c728e4384, stripped
//podman是一個程式
[root@localhost ~]# less /usr/bin/docker 
#!/bin/sh
[ -f /etc/containers/nodocker ] || \
echo "Emulate Docker CLI using podman. Create /etc/containers/nodocker to quiet msg." >&2
exec /usr/bin/podman "$@"
//可以查看到名字是docker但是執行的是podman
[root@localhost ~]# podman pull busybox
Resolved "busybox" as an alias (/etc/containers/registries.conf.d/000-shortnames.conf)
Trying to pull docker.io/library/busybox:latest...
Getting image source signatures
Copying blob 50783e0dfb64 done  
Copying config 7a80323521 done  
Writing manifest to image destination
Storing signatures
7a80323521ccd4c2b4b423fa6e38e5cea156600f40cd855e464cc52a321a24dd
//安裝好了podman不用啟動可以直接拉取鏡像,此處可以看見是/etc/containers/registries.conf.d/000-shortnames.conf這個倉庫配置文件裡面然後在docker.io官方倉庫hub.harbor.com裡面拉取下來了
[root@localhost ~]# vim /etc/containers/registries.conf.d/000-shortnames.conf
//可以查看到這裡全部是一些別名
因為我們不知道它會從哪個倉庫裡面去查找我們所需要東西,所以我們可以進行自定義倉庫
[root@localhost ~]# cd /etc/containers/
[root@localhost containers]# ls
certs.d  oci  policy.json  registries.conf  registries.conf.d  registries.d  storage.conf
//在registries.conf.d 這個裡面進行設置
[root@localhost containers]# vim registries.conf
unqualified-search-registries = ["docker.io"]
#unqualified-search-registries = ["registry.fedoraproject.org", "registry.access.redhat.com", "registry.centos.org", "docker.io"]
//可以把原來的配置複製一下再註釋,上面的就只保留docker.io
[[registry]]
prefix = "docker.io"
location = "docker.mirrors.ustc.edu.cn"
//配置加速器,此處是清華大學的(https://docker.mirrors.ustc.edu.cn/)
[root@localhost containers]# podman info
host:
  arch: amd64
  buildahVersion: 1.22.3
  cgroupControllers:
  - cpuset
  - cpu
  - cpuacct
  - blkio
  - memory
  - devices
  - freezer
  - net_cls
  - perf_event
  - net_prio
  - hugetlb
  - pids
  - rdma
  cgroupManager: systemd
  cgroupVersion: v1
  conmon:
    package: conmon-2.0.29-1.module_el8.5.0+890+6b136101.x86_64
    path: /usr/bin/conmon
    version: 'conmon version 2.0.29, commit: 84384406047fae626269133e1951c4b92eed7603'
  cpus: 4
  distribution:
    distribution: '"centos"'
    version: "8"
  eventLogger: file
  hostname: localhost
  idMappings:
    gidmap: null
    uidmap: null
  kernel: 4.18.0-257.el8.x86_64
  linkmode: dynamic
  memFree: 1109696512
  memTotal: 2043572224
  ociRuntime:
    name: runc
    package: runc-1.0.2-1.module_el8.5.0+911+f19012f9.x86_64
    path: /usr/bin/runc
    version: |-
      runc version 1.0.2
      spec: 1.0.2-dev
      go: go1.16.7
      libseccomp: 2.4.3
  os: linux
  remoteSocket:
    path: /run/podman/podman.sock
  security:
    apparmorEnabled: false
    capabilities: CAP_NET_RAW,CAP_CHOWN,CAP_DAC_OVERRIDE,CAP_FOWNER,CAP_FSETID,CAP_KILL,CAP_NET_BIND_SERVICE,CAP_SETFCAP,CAP_SETGID,CAP_SETPCAP,CAP_SETUID,CAP_SYS_CHROOT
    rootless: false
    seccompEnabled: true
    seccompProfilePath: /usr/share/containers/seccomp.json
    selinuxEnabled: true
  serviceIsRemote: false
  slirp4netns:
    executable: /usr/bin/slirp4netns
    package: slirp4netns-1.1.8-1.module_el8.5.0+890+6b136101.x86_64
    version: |-
      slirp4netns version 1.1.8
      commit: d361001f495417b880f20329121e3aa431a8f90f
      libslirp: 4.4.0
      SLIRP_CONFIG_VERSION_MAX: 3
      libseccomp: 2.4.3
  swapFree: 2181033984
  swapTotal: 2181033984
  uptime: 48m 30.51s
registries:
  docker.io:
    Blocked: false
    Insecure: false
    Location: docker.mirrors.ustc.edu.cn
    MirrorByDigestOnly: false
    Mirrors: null
    Prefix: docker.io
  search:
  - docker.io
store:
  configFile: /etc/containers/storage.conf
  containerStore:
    number: 0
    paused: 0
    running: 0
    stopped: 0
  graphDriverName: overlay
  graphOptions:
    overlay.mountopt: nodev,metacopy=on
  graphRoot: /var/lib/containers/storage
  graphStatus:
    Backing Filesystem: xfs
    Native Overlay Diff: "false"
    Supports d_type: "true"
    Using metacopy: "true"
  imageStore:
    number: 1
  runRoot: /run/containers/storage
  volumePath: /var/lib/containers/storage/volumes
version:
  APIVersion: 3.3.1
  Built: 1636493036
  BuiltTime: Wed Nov 10 05:23:56 2021
  GitCommit: ""
  GoVersion: go1.16.7
  OsArch: linux/amd64
  Version: 3.3.1
//查看podman的信息
[root@localhost ~]# podman pull centos
Resolved "centos" as an alias (/etc/containers/registries.conf.d/000-shortnames.conf)
Trying to pull quay.io/centos/centos:latest...
Getting image source signatures
Copying blob 7a0437f04f83 done  
Copying config 300e315adb done  
Writing manifest to image destination
Storing signatures
300e315adb2f96afe5f0b2780b87f28ae95231fe3bdd1e16b9ba606307728f55
//拉取鏡像嘗試一下,可以看見是直接去官方網站裡面拉取鏡像的

Podman的應用

podman的常用命令:
podman create      #創建容器
podman run         #創建並啟動容器
podman start       #啟動容器
podman ps          #查看容器
podman stop        #終止容器
podman restart     #重啟容器
podman attach      #進入容器
podman exec        #進入容器
podman export      #導出容器
podman import      #導入容器快照
podman rm          #刪除容器
podman logs        #查看日誌
podman search      #檢索鏡像
podman pull        #獲取鏡像
podman images      #列出鏡像
podman image Is    #列出鏡像
podman rmi         #刪除鏡像
podman image rm    #刪除鏡像
podman save        #導出鏡像
podman load        #導入鏡像
podmanfile         #定製鏡像(三個)
podman build       #構建鏡像
podman diff        #檢查容器文件系統上的更改
podman events      # 顯示事件
podmanfile         #常用指令(四個)
copy/cp            #複製文件
add                #高級複製
cmd                #容器啟動命令
env                #環境變數
expose             #暴露埠
healthcheck        #檢查運行管理的狀態
podman inspect     #顯示鏡像的配置

copy/cp

複製文件

[root@localhost ~]# podman ps   //查看正在運行的容器
CONTAINER ID  IMAGE       COMMAND     CREATED     STATUS      PORTS       NAMES
[root@localhost ~]# podman images  //列出鏡像
REPOSITORY                 TAG         IMAGE ID      CREATED        SIZE
docker.io/library/busybox  latest      7a80323521cc  2 weeks ago    1.47 MB
quay.io/centos/centos      latest      300e315adb2f  20 months ago  217 MB
[root@localhost ~]# podman run -it centos  //創建並運行這個容器
[root@a44e23e8b983 /]# ls
bin  etc   lib    lost+found  mnt  proc  run   srv  tmp  var
dev  home  lib64  media       opt  root  sbin  sys  usr
再打開一個終端:
[root@localhost ~]# podman ps     //查看正在運行的容器
CONTAINER ID  IMAGE                         COMMAND     CREATED        STATUS            PORTS       NAMES
a44e23e8b983  quay.io/centos/centos:latest  /bin/bash   8 minutes ago  Up 8 minutes ago              adoring_davinci
[root@localhost ~]# podman cp anaconda-ks.cfg a44e23e8b983:/  
//將這個外面的文件複製到容器裡面的根目錄下麵
回到之前的終端查看
[root@a44e23e8b983 /]# ls
anaconda-ks.cfg  dev  home  lib64       media  opt   root  sbin  sys  usr
bin              etc  lib   lost+found  mnt    proc  run   srv   tmp  var
//在容器裡面查看

start/stop

開啟/停止容器

[root@localhost ~]# podman start a44e23e8b983   
a44e23e8b983
[root@localhost ~]# podman ps
CONTAINER ID  IMAGE                         COMMAND     CREATED         STATUS             PORTS       NAMES
a44e23e8b983  quay.io/centos/centos:latest  /bin/bash   49 minutes ago  Up 23 seconds ago              adoring_davinci
[root@localhost ~]# podman stop a44e23e8b983 
a44e23e8b983
[root@localhost ~]# podman ps
CONTAINER ID  IMAGE       COMMAND     CREATED     STATUS      PORTS       NAMES

run/create

創建容器

[root@localhost ~]# podman run -it centos  //創建並運行這個容器
[root@localhost ~]# podman ps     //查看正在運行的容器
CONTAINER ID  IMAGE                         COMMAND     CREATED        STATUS            PORTS       NAMES
a44e23e8b983  quay.io/centos/centos:latest  /bin/bash   8 minutes ago  Up 8 minutes ago              adoring_davinci
[root@localhost ~]# podman pull httpd   
Resolving "httpd" using unqualified-search registries (/etc/containers/registries.conf)
Trying to pull docker.io/library/httpd:latest...
Getting image source signatures
Copying blob dcc4698797c8 done  
Copying blob a2abf6c4d29d done  
Copying blob 41c22baa66ec done  
Copying blob d982c879c57e done  
Copying blob 67283bbdd4a0 done  
Copying config dabbfbe0c5 done  
Writing manifest to image destination
Storing signatures
dabbfbe0c57b6e5cd4bc089818d3f664acfad496dc741c9a501e72d15e803b34
//拉取鏡像
[root@localhost ~]# podman images    
REPOSITORY                 TAG         IMAGE ID      CREATED        SIZE
docker.io/library/busybox  latest      7a80323521cc  2 weeks ago    1.47 MB
docker.io/library/httpd    latest      dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos      latest      300e315adb2f  20 months ago  217 MB
//列出鏡像
[root@localhost ~]# podman create --name web httpd  //此命令只是創建容器但是沒有啟動,一般不建議使用
f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a
[root@localhost ~]# podman ps
CONTAINER ID  IMAGE       COMMAND     CREATED     STATUS      PORTS       NAMES
[root@localhost ~]# podman ps -a
CONTAINER ID  IMAGE                           COMMAND           CREATED         STATUS                    PORTS       NAMES
a44e23e8b983  quay.io/centos/centos:latest    /bin/bash         53 minutes ago  Exited (0) 3 minutes ago              adoring_davinci
f7e53678f186  docker.io/library/httpd:latest  httpd-foreground  8 seconds ago   Created                               web

diff

檢查容器文件系統上的更改

[root@localhost ~]# podman ps
CONTAINER ID  IMAGE                           COMMAND           CREATED        STATUS            PORTS       NAMES
f7e53678f186  docker.io/library/httpd:latest  httpd-foreground  5 minutes ago  Up 4 seconds ago              web
[root@localhost ~]# podman diff f7e53678f186 
C /usr
C /usr/local
C /usr/local/apache2
C /usr/local/apache2/logs
A /usr/local/apache2/logs/httpd.pid
C /etc

exec

進入正在運行的容器

[root@localhost ~]# podman ps
CONTAINER ID  IMAGE                           COMMAND           CREATED        STATUS            PORTS       NAMES
f7e53678f186  docker.io/library/httpd:latest  httpd-foreground  8 minutes ago  Up 3 minutes ago              web
[root@localhost ~]# podman exec -it f7e53678f186 /bin/sh
# ls
bin  build  cgi-bin  conf  error  htdocs  icons  include  logs  modules

healthcheck

檢查運行管理的狀態

[root@localhost ~]# podman ps
CONTAINER ID  IMAGE                           COMMAND           CREATED         STATUS            PORTS       NAMES
f7e53678f186  docker.io/library/httpd:latest  httpd-foreground  11 minutes ago  Up 5 minutes ago              web
[root@localhost ~]# podman healthcheck run web 
Error: container f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a has no defined healthcheck

inspect

顯示鏡像的配置

[root@localhost ~]# podman inspect web 
[
    {
        "Id": "f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a",
        "Created": "2022-08-15T13:28:43.182514247+08:00",
        "Path": "httpd-foreground",
        "Args": [
            "httpd-foreground"
        ],
        "State": {
            "OciVersion": "1.0.2-dev",
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 327830,
            "ConmonPid": 327818,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2022-08-15T13:33:45.480354789+08:00",
            "FinishedAt": "2022-08-15T13:33:36.646016512+08:00",
            "Healthcheck": {
                "Status": "",
                "FailingStreak": 0,
                "Log": null
            }
        },
        "Image": "dabbfbe0c57b6e5cd4bc089818d3f664acfad496dc741c9a501e72d15e803b34",
        "ImageName": "docker.io/library/httpd:latest",
        "Rootfs": "",
        "Pod": "",
        "ResolvConfPath": "/run/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/resolv.conf",
        "HostnamePath": "/run/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/hostname",
        "HostsPath": "/run/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/hosts",
        "StaticDir": "/var/lib/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata",
        "OCIConfigPath": "/var/lib/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/config.json",
        "OCIRuntime": "runc",
        "ConmonPidFile": "/run/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/conmon.pid",
        "PidFile": "/run/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/pidfile",
        "Name": "web",
        "RestartCount": 0,
        "Driver": "overlay",
        "MountLabel": "system_u:object_r:container_file_t:s0:c556,c843",
        "ProcessLabel": "system_u:system_r:container_t:s0:c556,c843",
        "AppArmorProfile": "",
        "EffectiveCaps": [
            "CAP_CHOWN",
            "CAP_DAC_OVERRIDE",
            "CAP_FOWNER",
            "CAP_FSETID",
            "CAP_KILL",
            "CAP_NET_BIND_SERVICE",
            "CAP_NET_RAW",
            "CAP_SETFCAP",
            "CAP_SETGID",
            "CAP_SETPCAP",
            "CAP_SETUID",
            "CAP_SYS_CHROOT"
        ],
        "BoundingCaps": [
            "CAP_CHOWN",
            "CAP_DAC_OVERRIDE",
            "CAP_FOWNER",
            "CAP_FSETID",
            "CAP_KILL",
            "CAP_NET_BIND_SERVICE",
            "CAP_NET_RAW",
            "CAP_SETFCAP",
            "CAP_SETGID",
            "CAP_SETPCAP",
            "CAP_SETUID",
            "CAP_SYS_CHROOT"
        ],
        "ExecIDs": [],
        "GraphDriver": {
            "Name": "overlay",
            "Data": {
                "LowerDir": "/var/lib/containers/storage/overlay/f1aca06344b90a296c3935de55948a2e384af058b8026eff8d70367d9ba65eb4/diff:/var/lib/containers/storage/overlay/fbe4081f229c9bfb37ed4b0df548f053005c7268f32cce47ac3a5530b75565f5/diff:/var/lib/containers/storage/overlay/1e878596d57304e7f3aa17328742283948d033f9110501481771061e41cc34f2/diff:/var/lib/containers/storage/overlay/03f787f87707a04d0c7bc9a113e84d4618c1694280a63581dddd652d2084ad47/diff:/var/lib/containers/storage/overlay/2edcec3590a4ec7f40cf0743c15d78fb39d8326bc029073b41ef9727da6c851f/diff",
                "MergedDir": "/var/lib/containers/storage/overlay/db189872505617ea513a30152e77e54fe27a4acf555f34762646e5ecd1f7abcc/merged",
                "UpperDir": "/var/lib/containers/storage/overlay/db189872505617ea513a30152e77e54fe27a4acf555f34762646e5ecd1f7abcc/diff",
                "WorkDir": "/var/lib/containers/storage/overlay/db189872505617ea513a30152e77e54fe27a4acf555f34762646e5ecd1f7abcc/work"
            }
        },
        "Mounts": [],
        "Dependencies": [],
        "NetworkSettings": {
            "EndpointID": "",
            "Gateway": "10.88.0.1",
            "IPAddress": "10.88.0.5",
            "IPPrefixLen": 16,
            "IPv6Gateway": "",
            "GlobalIPv6Address": "",
            "GlobalIPv6PrefixLen": 0,
            "MacAddress": "26:5d:42:f0:25:33",
            "Bridge": "",
            "SandboxID": "",
            "HairpinMode": false,
            "LinkLocalIPv6Address": "",
            "LinkLocalIPv6PrefixLen": 0,
            "Ports": {},
            "SandboxKey": "/run/netns/cni-7d73fe83-e440-4ebe-6434-44b1f9ff7777",
            "Networks": {
                "podman": {
                    "EndpointID": "",
                    "Gateway": "10.88.0.1",
                    "IPAddress": "10.88.0.5",
                    "IPPrefixLen": 16,
                    "IPv6Gateway": "",
                    "GlobalIPv6Address": "",
                    "GlobalIPv6PrefixLen": 0,
                    "MacAddress": "26:5d:42:f0:25:33",
                    "NetworkID": "podman",
                    "DriverOpts": null,
                    "IPAMConfig": null,
                    "Links": null
                }
            }
        },
        "ExitCommand": [
            "/usr/bin/podman",
            "--root",
            "/var/lib/containers/storage",
            "--runroot",
            "/run/containers/storage",
            "--log-level",
            "warning",
            "--cgroup-manager",
            "systemd",
            "--tmpdir",
            "/run/libpod",
            "--runtime",
            "runc",
            "--storage-driver",
            "overlay",
            "--storage-opt",
            "overlay.mountopt=nodev,metacopy=on",
            "--events-backend",
            "file",
            "container",
            "cleanup",
            "f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a"
        ],
        "Namespace": "",
        "IsInfra": false,
        "Config": {
            "Hostname": "f7e53678f186",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
                "PATH=/usr/local/apache2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
                "TERM=xterm",
                "container=podman",
                "HTTPD_VERSION=2.4.52",
                "HTTPD_SHA256=0127f7dc497e9983e9c51474bed75e45607f2f870a7675a86dc90af6d572f5c9",
                "HTTPD_PATCHES=",
                "HTTPD_PREFIX=/usr/local/apache2",
                "HOME=/root",
                "HOSTNAME=f7e53678f186"
            ],
            "Cmd": [               //容器啟動命令
                "httpd-foreground"
            ],
            "Image": "docker.io/library/httpd:latest",
            "Volumes": null,
            "WorkingDir": "/usr/local/apache2",
            "Entrypoint": "",
            "OnBuild": null,
            "Labels": null,
            "Annotations": {
                "io.container.manager": "libpod",
                "io.kubernetes.cri-o.Created": "2022-08-15T13:28:43.182514247+08:00",
                "io.kubernetes.cri-o.TTY": "false",
                "io.podman.annotations.autoremove": "FALSE",
                "io.podman.annotations.init": "FALSE",
                "io.podman.annotations.privileged": "FALSE",
                "io.podman.annotations.publish-all": "FALSE",
                "org.opencontainers.image.stopSignal": "28"
            },
            "StopSignal": 28,
            "CreateCommand": [
                "podman",
                "create",
                "--name",
                "web",
                "httpd"
            ],
            "Umask": "0022",
            "Timeout": 0,
            "StopTimeout": 10
        },
        "HostConfig": {
            "Binds": [],
            "CgroupManager": "systemd",
            "CgroupMode": "host",
            "ContainerIDFile": "",
            "LogConfig": {
                "Type": "k8s-file",
                "Config": null,
                "Path": "/var/lib/containers/storage/overlay-containers/f7e53678f186f326ee687436b53693836ea63427986cfd15ef78c4b5ca99571a/userdata/ctr.log",
                "Tag": "",
                "Size": "0B"
            },
            "NetworkMode": "bridge",
            "PortBindings": {},
            "RestartPolicy": {
                "Name": "",
                "MaximumRetryCount": 0
            },
            "AutoRemove": false,
            "VolumeDriver": "",
            "VolumesFrom": null,
            "CapAdd": [],
            "CapDrop": [
                "CAP_AUDIT_WRITE",
                "CAP_MKNOD"
            ],
            "Dns": [],
            "DnsOptions": [],
            "DnsSearch": [],
            "ExtraHosts": [],
            "GroupAdd": [],
            "IpcMode": "private",
            "Cgroup": "",
            "Cgroups": "default",
            "Links": null,
            "OomScoreAdj": 0,
            "PidMode": "private",
            "Privileged": false,
            "PublishAllPorts": false,
            "ReadonlyRootfs": false,
            "SecurityOpt": [],
            "Tmpfs": {},
            "UTSMode": "private",
            "UsernsMode": "",
            "ShmSize": 65536000,
            "Runtime": "oci",
            "ConsoleSize": [
                0,
                0
            ],
            "Isolation": "",
            "CpuShares": 0,
            "Memory": 0,
            "NanoCpus": 0,
            "CgroupParent": "",
            "BlkioWeight": 0,
            "BlkioWeightDevice": null,
            "BlkioDeviceReadBps": null,
            "BlkioDeviceWriteBps": null,
            "BlkioDeviceReadIOps": null,
            "BlkioDeviceWriteIOps": null,
            "CpuPeriod": 0,
            "CpuQuota": 0,
            "CpuRealtimePeriod": 0,
            "CpuRealtimeRuntime": 0,
            "CpusetCpus": "",
            "CpusetMems": "",
            "Devices": [],
            "DiskQuota": 0,
            "KernelMemory": 0,
            "MemoryReservation": 0,
            "MemorySwap": 0,
            "MemorySwappiness": 0,
            "OomKillDisable": false,
            "PidsLimit": 2048,
            "Ulimits": [
                {
                    "Name": "RLIMIT_NOFILE",
                    "Soft": 1048576,
                    "Hard": 1048576
                },
                {
                    "Name": "RLIMIT_NPROC",
                    "Soft": 4194304,
                    "Hard": 4194304
                }
            ],
            "CpuCount": 0,
            "CpuPercent": 0,
            "IOMaximumIOps": 0,
            "IOMaximumBandwidth": 0,
            "CgroupConf": null
        }
    }
]

image rm

刪除鏡像

[root@localhost ~]# podman images
REPOSITORY                 TAG         IMAGE ID      CREATED        SIZE
docker.io/library/busybox  latest      7a80323521cc  2 weeks ago    1.47 MB
docker.io/library/httpd    latest      dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos      latest      300e315adb2f  20 months ago  217 MB
[root@localhost ~]# podman image rm busybox
Untagged: docker.io/library/busybox:latest
Deleted: 7a80323521ccd4c2b4b423fa6e38e5cea156600f40cd855e464cc52a321a24dd
[root@localhost ~]# podman images
REPOSITORY               TAG         IMAGE ID      CREATED        SIZE
docker.io/library/httpd  latest      dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos    latest      300e315adb2f  20 months ago  217 MB
[root@localhost ~]# podman rm $(podman ps -qa)
a44e23e8b9833af02f0ba614eb09ec61c567dce27ca1eb878941854cd8e2a4f9
961220f07452f14df4439a089123a08172216b5b92659fee345f778fab2edc13
//podman ps -qa 取出容器的id號
[root@localhost ~]# podman ps -a
CONTAINER ID  IMAGE       COMMAND     CREATED     STATUS      PORTS       NAMES
podman rm $(podman ps -qa)刪除所有容器

login/logout

登錄和登出docker.io私有倉庫

[root@localhost ~]# podman login docker.io 
Username: lvnanhai66
Password: 
Login Succeeded!
[root@localhost ~]# podman logout
Removed login credentials for docker.io

history

顯示指定鏡像的歷史記錄

[root@localhost ~]# podman image history httpd
ID            CREATED       CREATED BY                                     SIZE              COMMENT
dabbfbe0c57b  7 months ago  /bin/sh -c #(nop)  CMD ["httpd-foreground"]    0 B               
<missing>     7 months ago  /bin/sh -c #(nop)  EXPOSE 80                   0 B               
<missing>     7 months ago  /bin/sh -c #(nop) COPY file:c432ff61c4993e...  3.58 kB           
<missing>     7 months ago  /bin/sh -c #(nop)  STOPSIGNAL SIGWINCH         0 B               
<missing>     7 months ago  /bin/sh -c set -eux;                                             savedAptMark="$(apt...  61.1 MB     
<missing>     7 months ago  /bin/sh -c #(nop)  ENV HTTPD_PATCHES=          0 B               
<missing>     7 months ago  /bin/sh -c #(nop)  ENV HTTPD_SHA256=0127f7...  0 B               
<missing>     7 months ago  /bin/sh -c #(nop)  ENV HTTPD_VERSION=2.4.52    0 B               
<missing>     7 months ago  /bin/sh -c set -eux;                           apt-get update;   apt...      2.72 MB     
<missing>     7 months ago  /bin/sh -c #(nop) WORKDIR /usr/local/apache2   0 B               
<missing>     7 months ago  /bin/sh -c mkdir -p "$HTTPD_PREFIX"            && ch...          3.07 kB     
<missing>     7 months ago  /bin/sh -c #(nop)  ENV PATH=/usr/local/apa...  0 B               
<missing>     7 months ago  /bin/sh -c #(nop)  ENV HTTPD_PREFIX=/usr/l...  0 B               
<missing>     7 months ago  /bin/sh -c #(nop)  CMD ["bash"]                0 B               
<missing>     7 months ago  /bin/sh -c #(nop) ADD file:09675d11695f65c...  83.9 MB           

list/ls/images

列出本地存儲鏡像

[root@localhost ~]# podman image list 
REPOSITORY               TAG         IMAGE ID      CREATED        SIZE
docker.io/library/httpd  latest      dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos    latest      300e315adb2f  20 months ago  217 MB
[root@localhost ~]# podman image ls
REPOSITORY               TAG         IMAGE ID      CREATED        SIZE
docker.io/library/httpd  latest      dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos    latest      300e315adb2f  20 months ago  217 MB
[root@localhost ~]# podman images
REPOSITORY               TAG         IMAGE ID      CREATED        SIZE
docker.io/library/httpd  latest      dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos    latest      300e315adb2f  20 months ago  217 MB

save

將鏡像保存到本地

[root@localhost ~]# podman image save httpd > httpd.tar
[root@localhost ~]# ls
anaconda-ks.cfg  httpd.tar

tag

對鏡像進行修改標簽

[root@localhost ~]# podman tag httpd dabbfbe0c57b/httpd:v1.0
[root@localhost ~]# podman image list 
REPOSITORY                    TAG         IMAGE ID      CREATED        SIZE
docker.io/library/httpd       latest      dabbfbe0c57b  7 months ago   148 MB
localhost/dabbfbe0c57b/httpd  v1.0        dabbfbe0c57b  7 months ago   148 MB
quay.io/centos/centos         latest      300e315adb2f  20 months ago  217 MB

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 書籍下載地址: Ansi Common Lisp 中文版|百度網盤 實用Common.Lisp編程 .pdf|百度網盤 LISP指令速查網站推薦: Simplified Common Lisp reference (jtra.cz) 我製作的表格: 由於Common LISP命令很多,經常忘,所以做 ...
  • #使用Nginx在 Linux 上托管 ASP.NET Core 6.0應用:GitHub Actions自動部署 前言 本文主要參考微軟這篇文檔而來 Host ASP.NET Core on Linux with Nginx,並使用Github Actions做CI&CD,部署到阿裡雲伺服器,所有 ...
  • 一、在使用WinDbg調試之前,我們先使用VS的調試功能 1、文件 -> 打開 -> 文件 -> 打開Dump文件 2、調試 -> 選項 -> 調試 -> 符號 -> 添加該應用的.pdb所在的文件夾 3、使用 僅限托管 進行調試 正常情況下會執行到拋出異常的位置,並且顯示異常詳情。 二、WinDb ...
  • 一:背景 上一篇我們聊到瞭如何用 PerfView 去偵察 NTHeap 的記憶體泄漏,這種記憶體泄漏往往是用 C 的 malloc 或者 C++ 的 new 分配而不釋放所造成的,這一篇我們來聊一下由 VirtualAlloc 方法造成的泄漏如何去甄別? 瞭解 VirtualAlloc 的朋友肯定說, ...
  • podman基礎用法 podman常用命令 查看版本 [root@localhost ~]# podman -v podman version 3.3.1 [root@localhost ~]# podman version Version: 3.3.1 API Version: 3.3.1 Go ...
  • 目錄 一、前景回顧 二、任務切換相關 三、實現TSS 四、運行測試 一、前景回顧 在上一回我們已經實現了鍵盤的驅動編寫和環形緩衝區的實現,現在讓我們來想這麼一個問題: 一直以來我們的程式都在最高特權級0下工作,這意味著任何程式都和操作系統平起平坐,可以改動任何資源。如果不改變這種現狀的話,某個不聽話 ...
  • 蘋果滑鼠右鍵無法新建txt文檔?iRightMouse mac版是Macos上一款超級右鍵滑鼠輔助工具,彌補了蘋果右鍵功能較弱的短板,為mac增加右鍵新建菜單,蘋果右鍵可以新建TXT,為用戶豐富蘋果右鍵功能。歡迎大家前來體驗! 詳情:iRightMouse for Mac(超級右鍵滑鼠輔助工具) i ...
  • 以下說明在 Ubuntu 下如何配置 HC32L110 的燒錄環境, 當前使用的是 JLink. 可以使用 JFlashExe 通過界面進行操作, 也可以通過 JLinkExe 命令行進行操作 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...