首页 > 其他分享 >docker/podman

docker/podman

时间:2022-10-21 15:47:59浏览次数:84  
标签:容器 sudo podman 镜像 docker 简写

虚拟化技术

虚拟化技术:把真实物理机子中剩余的资源重新整合,基于虚拟机软件创建出来一台新的虚拟的计算机提供给开发者使用。
优点:
   虚拟化 使用软件/硬件的方法重新定义划分计算机资源,可以实现计算机资源的动态分配、灵活调度、跨域共享,提高IT资源利用率,降低成本,加快部署,极大增强系统整体安全性和可靠性。使IT资源能够真正成为社会基础设施,服务于各行各业中灵活多变的应用需求。
​
虚拟化技术有5种不同的实现方案:
1. 硬件虚拟化
   需要购买虚拟化设备(虚拟机类似主机)
2. 分区虚拟化
   一台电脑下可以实际安装多个操作系统。开机的时候,就固定分配好了内存。 
3. 虚拟机技术[应用虚拟化]
   通过在操作系统中安装软件来实现,例如:VMware,virtualbox,在vm中创建虚拟机,搭建操作系统,在虚拟机运行的时候,由vm动态向真实电脑申请分配硬件资源[cpu,内存,显卡网络等等]。
4. 准虚拟机技术
   是上面第2和第3中的混合产物,不需要安装vm也不需要分区,而是由操作系统本身提供出来了一个虚拟层来实现的。
   例如;xven或者window10的HyperV都是这种实现。鸿蒙系统
​
因为上面不管哪一种虚拟化技术,都会出现一个问题:
就是为了让虚拟出来的操作系统能正常运作起来都需要 实实在在 向真实物理机申请固定的对应计算机 资源。而且为了能让虚拟出来的操作系统能正常运作,物理机要分配各种的硬件资源,这样很大程度上存在资源的消耗,降低物理机的性能。而这个过程用户完全有可能仅仅只是了为运行某几个软件而已。所以为了更好的提升用户的体验,提升系统的性能,减低不必要的计算机资源消耗,所以出现了  一种新的虚拟化技术。
​
新的虚拟化技术:
容器化技术!!!
比较流行的容器化技术有:docker和podman
目前在外界使用过程中,比较常用的还是docker


docker(类似于VMware,但它会导致真实物理机的资源的浪费)仅仅保存了一些操作系统关键性文件以及开发者需要运行的软件,(不包含网卡内存界面等资源)可以极大降低程序文件大小

docker提供给开发者使用的方式提供了3种:(类似于VMware,但它会导致真实物理机的资源的浪费)
1. 终端命令[通过终端命令逐步操作docker]
2. dockerFile[脚本文件,通过脚本对docker进行封装和操作单个镜像]
3. docker-compose [通过脚本对docker的多个镜像/容器进行组合编排的技术, 是python实现的一种技术]

一张图看懂dacker,容器,镜像的关系:

 

 

我们获取镜像文件,可以直接去官方网站上获取: https://hub.docker.com/

 

 

 

ubuntu安装docker:

更新ubuntu的apt源索引

sudo apt-get update

 

安装包允许apt通过HTTPS使用仓库

sudo dpkg --configure -a
sudo apt-get install apt-transport-https ca-certificates curl software-properties-common
 

 

添加Docker官方GPG key【这个是国外服务器地址,所以网路不好的时候,会失败!在网路好的情况下,多执行几次就没问题了】

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

 

 

设置Docker最新稳定版仓库

sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"

 

添加仓库后,更新apt源索引

sudo apt-get update

 

前面的准备工作完成以后,接下来安装最新版Docker CE(社区版 开源)

sudo apt-get install docker-ce

 

通过下载一个叫hello-world的镜像并运行起来,以此来检查Docker CE是否安装正确并能正常使用。

sudo docker run hello-world

 

出现了helo from Docker则表示上面的安装成功!

 

 

知道上面docker的安装步骤就行不需要安装,在ubuntu中已经安装了一个虚拟化容器了podman

Docker/podman 命令

dockerh 和podman区别:

docker在ubuntu使用过程中,需要左边加上sudo,而podman不需要。同时下面所有的命令在docker和podman里面是通用的。

所以这里全部写成docker了,在使用podman操作以下以下命令时,直接把docker换成podman即可。

docker提供给开发者使用的方式提供了3种:

1、终端命令的操作

通用命令

查看docker 当前版本

sudo docker version
docker -v
# podman version
# podman -v

 

管理docker运行

# 启动docker
sudo service docker start
# sudo service podman start
​
# 停止docker
sudo service docker stop
# sudo service podman stop
# 无法停止用下面的
# systemctl stop podman.socket
# systemctl stop podman
​
# 重启docker
sudo service docker restart
# sudo service podman restart
​
# 查看docker状态
sudo service docker status
# sudo service podman status

 

 

镜像操作[image]

列出本地所有镜像
sudo docker image ls --all
# 简写
# sudo docker image ls
# 简写
# sudo docker images
​
# podman
# podman images

 

REPOSITORYTAGIMAGE IDCREATEDSIZE
当前镜像的作者以及镜像名 镜像版本号 镜像唯一标记符 镜像创建/析出时间 镜像文件的大小

 

拉取镜像

docker/podman支持通过网络拉去镜像源站的所有镜像。默认使用的工具就是git工具。

官方镜像源:https://hub.docker.com/

拉取镜像时,如果不指定版本号,默认拉取最新版本的镜像

sudo docker image pull <镜像名称:版本号>
# 简写
# sudo docker pull <镜像名称:版本号>
​
# podman
# podman pull <镜像名称:版本号>

 

删除镜像

删除的时候,必须注意是否有容器在运行当前镜像文件,如果在使用,则需要先删除容器,才能删除镜像

sudo docker image rm <镜像名称/镜像ID:版本号>
# 简写 
# sudo docker rmi <镜像名称/镜像ID:版本号>
​
# podman
# podman image rm <镜像名称/镜像ID:版本号>
# podman rmi <镜像名称/镜像ID:版本号>

 

删除的镜像如果被容器提前使用了,则错误如下:

 

 

解决方案:先删除当前镜像对应的容器,接着才能删除镜像。

 

把docker中的镜像打包成文件

用于分享发送给他人,或备份

sudo docker save -o 文件名.tar.gz  镜像名:版本号
​
# podman 
# podman save -o 文件名.tar.gz  镜像名:版本号

 

把下载好的在本地的镜像文件加载到docker中
sudo docker load -i 文件名.tar.gz
​
# podman
# podman load -i  文件名.tar.gz
 

 

上传镜像

使用之前,必须先到阿里云/dockerhub官方注册账号并创建对应的仓库。

sudo docker login -u <账号名>
# podman login -u <账号名>
​
sudo docker push <镜像名称/镜像ID>:<版本号>
# podman push <镜像名称/镜像ID>:<版本号>
 

 

 

容器操作[container]

创建容器

必须先有镜像,才能运行创建容器,需要指定使用的镜像名,并且设置创建容器以后,执行对应的第一条命令

sudo docker run <参数选项> --name=容器名 <镜像名称:镜像版本> <容器启动后的第一个命令>
# podman run <参数选项> --name=容器名 <镜像名称:镜像版本> <容器启动后的第一个命令>

 

例如:使用"hello-world"镜像,创建一个hello-world容器。(注意:如果运行容器时,本地没有对应的镜像或对应镜像的版本,则docker/podman会自动往线上的源服务器中搜索是否有对应的镜像并自动下载的,执行pull镜像操作)。

sudo docker run hello-world
# podman run hello-world

 

例如:docker使用ubuntu:20.04镜像,创建一个名为ubuntu1的容器

sudo docker pull ubuntu:20.04
sudo docker run -it --name=ubuntu1 ubuntu:20.04 bash
​
# podman pull ubuntu:20.04
# podman run -it --name=ubuntu1 ubuntu:20.04 bash

 

注意:启动容器时,如果设置了-it选项参数表示让容器启动以后运行bash解析器(一个终端可以输入命令),(我们可以通过bash终端输入命令操作该容器,)但是如果使用了exit关闭bash以后,容器会自动关闭。那如果设置了-itd选项参数,那么run命令执行以后,docker会自动以守护进程的方式创建一个容器,容器会一直运行着。

 

docker run的参数选项

-t 表示容器启动后会进入其命令行终端

-i 表示以“交互模式”运行容器(没有i就没有交互 没法输入 必须写上)

--name 表示设置容器的名称,注意容器名是唯一的,尽量遵循python变量名的规范。

-v 目录影射,相当于把容器外部的物理机的目录与容器内部的目录实现共享,改了里面相当于改了外面

-p 端口影射,把物理机的一个端口和容器内部的端口进行绑定。访问了物理机的端口相当于访问了容器的对应端口

 

 

-e 设置环境变量,在部分容器中,需要设置环境变量时使用到(这样通过os.vir就可以对外操作了)

 

 

--restart=always 设置容器随着docker开机自启,docker/podman中创建的容器默认是不会开机自启,同时podman是没有这个选项的以后有别的方法

--network=host 设置网络模式,与-p冲突,一般设置-p以后不要设置--network

例如,使用ubuntu镜像,创建一个名为ubuntu2,并且在后台运行的容器像

sudo docker run -itd --name=ubuntu2 ubuntu<:版本> ubuntu
# podman run -itd --name=ubuntu2 ubuntu<:版本> ubuntu

 

-d 创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器内部的,需要使用docker exec -it 命令才能进入容器内部)

 

列出所有容器
sudo docker container ls                      # 所有正在启动运行的容器
# 简写 sudo docker ps
# podman ps
​
sudo docker container ls --all                # 所有容器[不管是否在启动运行中]
# 简写 sudo docker ps --all
# podman ps --all

 

CONTAINER IDIMAGECOMMANDCREATEDSTATUSPORTSNAMES
容器的唯一标记ID 容器的镜像名 容器运行以后默认执行的第一个命令 容器创建时间 容器的运行状态,Up表示容器正在正在启动,Exitd表示容器已经关闭了。 容器与操作系统的端口映射 容器名

 

启动容器

可以同时启动多个容器,容器之间使用空格隔开

# 启动一个容器[被开启的容器默认会以守护式容器在后台持续运行]
sudo docker container start <容器名称/容器ID>
# 简写 sudo docker start  <容器名称/容器ID>
# podman start  <容器名称/容器ID>
​
# 启动多个容器
sudo docker container start <容器名称/容器ID>  <容器名称/容器ID> <容器名称/容器ID>
# 简写 sudo docker start <容器名称/容器ID>  <容器名称/容器ID> <容器名称/容器ID>
# podman start <容器名称/容器ID>  <容器名称/容器ID> <容器名称/容器ID>
 

 

停止容器
sudo docker container stop <容器名称/容器ID>
# 简写 sudo docker stop  <容器名称/容器ID>
# podman stop  <容器名称/容器ID>
​
# 停止多个容器
sudo docker container stop <容器名称/容器ID>  <容器名称/容器ID>
# 简写 sudo docker stop <容器名称/容器ID>  <容器名称/容器ID>
# podman stop <容器名称/容器ID>  <容器名称/容器ID>
 

 

杀死容器

该命令在容器无法停止的时使用,注意不能滥用,这种操作有可能被导致容器里面运行的文件丢失!!!

sudo docker container kill <容器名称/容器ID>
# 简写 sudo docker kill <容器名称/容器ID>
# podman kill <容器名称/容器ID>
​
# 杀死多个容器
sudo docker container kill <容器名称/容器ID>  <容器名称/容器ID>
# 简写 sudo docker kill <容器名称/容器ID>  <容器名称/容器ID>
# podman kill <容器名称/容器ID>  <容器名称/容器ID>

 

进入容器

要进入容器,必须当前容器是启动状态的,exec命令不需要加上-d选项,但需要指定指定容器启动后的第一个命令。

sudo docker container exec -it <容器名称/容器ID>  <第一个命令>
# sudo docker exec -it <容器名称/容器ID>  <第一个命令>
# podman exec -it <容器名称/容器ID>  <第一个命令>

 

第一个命令一般都是bash,也可以是其他允许开发者输入信息的其他软件命令

 

删除容器

注意:docker/podman只能删除关闭的容器,无法删除一个正在运行的容器。

sudo docker  container rm <容器名称/容器ID>
# 简写 sudo docker rm <容器名称/容器ID>
# podman rm <容器名称/容器ID>
​
# 删除多个容器
sudo docker  container rm <容器名称/容器ID>  <容器名称/容器ID>
# 简写 sudo docker rm <容器名称/容器ID>  <容器名称/容器ID>
# podman rm <容器名称/容器ID>  <容器名称/容器ID>

 

复制文件(外界复制到容器中)
# 命令基本格式:
sudo docker container cp <源文件地址> <保存文件地址>
​
​
# 从物理机中复制一个文件到指定容器的内部指定路径中
sudo docker container cp <物理机路径> <容器名称/容器ID>:<容器路径>
# 简写 sudo docker cp <物理机路径> <容器名称/容器ID>:<容器路径>
# podman cp  <物理机路径> <容器名称/容器ID>:<容器路径>
​
​
# 指定容器的内部指定路径中复制一个文件到物理机指定路径中保存
sudo docker container cp <容器名称/容器ID>:<容器路径> <物理机路径>
# 简写 sudo docker cp <容器名称/容器ID>:<容器路径> <物理机路径>
# podman cp <容器名称/容器ID>:<容器路径> <物理机路径>

 

 

把容器保存成镜像备份
sudo docker container commit <容器名称/容器ID>  <新镜像名:镜像自定义版本>
# 简写 sudo docker commit <容器名称/容器ID>  <新镜像名:镜像自定义版本>
# podman commit <容器名称/容器ID>  <新镜像名:镜像自定义版本>

 

标签:容器,sudo,podman,镜像,docker,简写
From: https://www.cnblogs.com/erhuoyuan/p/16813672.html

相关文章

  • 如何搭建自己的CI/CD平台:Gitlab+Jenkins+Docker+Harbor+K8s集群搭建CICD平台(持续集
    如何搭建自己的CI/CD平台:Gitlab+Jenkins+Docker+Harbor+K8s集群搭建CICD平台(持续集成部署Hexo博客Demo)写在前面聊聊CICD的环境搭建以及一个基于Hexo的博客系统在C......
  • 【DevOps】DevOps 实践之路(一):谈谈 DevOps、云原生、Docker、K8s
    【DevOps】DevOps实践之路(一):谈谈DevOps、云原生、Docker、K8s前言最近决定写一个系列文章,名称就叫DevOps实践之路,一直想做目前业务的自动化运维工作,但是由于涉......
  • Docker Jenkins 安装配置
    由于低版本的安装插件很麻烦,插件版本依赖很坑,所以选择了安装最新版Jenkins,并使用docker安装#https://www.jenkins.io/zh/doc/book/installing/#docker[root@localhos......
  • Prometheus监控docker容器
    使用prometheus的特性易管理性Prometheus核心部分只有一个单独的二进制文件,可直接在本地工作,不依赖于分布式存储不依赖分布式存储,单服务器节点是自治的高效单一Promethe......
  • 云原生实战K8s+Docker+DevOps+Jenkins
    云原生实战K8s+Docker+DevOps+Jenkins应用部署实战ruo-yi-cloud1、项目https://gitee.com/y_project/RuoYi-Cloud2、架构下载项目本地环境nacos启动单机模式mys......
  • 大厂进阶篇Docker与微服务实战-技术点从入门到高级全面覆盖
     说明随便创建个SpringBoot项目,写个Controller方法,然后用maven配置打包项目成xx.jar,调用接口如下面图片,当做案例进行测试。二、高级篇(大厂进阶)3.Docker微服务实......
  • centos 7.6 docker nginx
    一、安装docker二、创建Dockerfile#创建文件夹mkdircentos_nginxcdcentos_nginxvimDockerfile#指定使用那个基础镜像[email protected]......
  • docker安装postgres并启用postgis扩展
    镜像查看所有镜像dockerimages可以直接拉取postgis镜像dockerpullpostgis也可以在已有镜像上安装postgres,再启用扩展;dockerpullpostgres容器查看启动的容器......
  • Docker 总体架构图解
    Docker的总体架构Docker是一个C/S模式的架构,后端是一个松耦合架构,模块各司其职。下图是它的总体架构图:1、用户使用DockerClient与DockerDaemon建立通信,并发......
  • docker 命令
    启动docker:systemctlstartdocker停止docker:systemctlstopdocker重启docker:systemctlrestartdocker查看docker状态:systemctlstatusdocker刷新dock......