当前位置:   article > 正文

Docker之镜像与容器的相关操作_容器和镜像相关

容器和镜像相关

目录

 一、Docker镜像

搜索镜像

下载镜像 

查看宿主机上的镜像

删除镜像 

二、Docker容器

创建容器 

查看容器

启停容器

删除容器

进入容器

创建/启动/进入容器

退出容器

查看容器内部信息


一、Docker镜像

Docker 运行容器前需要本地存在对应的镜像, 如果镜像不存在, Docker 会尝试先从默认镜像仓库下载(默认使用 Docker Hub公共注册服务器中的仓库), 用户也可以通过配置,使用自定义的镜像仓库。

搜索镜像

docker search 镜像名称

例如:

docker search centos

下载镜像 

docker pull 镜像

例如, 获取一个 centos 系统的基础镜像可以使用如下的命令:

  1. # 未指定版本一般会使用latest(最新的)版本
  2. docker pull centos
  3. # 或者直接指定版本
  4. docker pull centos:版本号

查看宿主机上的镜像

docker images

/var/lib/docker 为 docker 默认安装目录

  1. # 切换目录
  2. cd /var/lib/docker/containers
  3. # 查看目录下的文件
  4. ls

删除镜像 

docker rmi 镜像ID/标签

例如:

  1. # 根据镜像ID删除
  2. docker rmi feb5d9fea6a5
  3. # 根据镜像标签(版本)
  4. docker rmi hello-world:latest 或 docker rmi hello-world:版本号

如果提示镜像被使用,需要先停止某个ID的容器,然后先删除容器再删除镜像。或者强制删除镜像。

强制删除镜像:  

docker rmi -f centos:版本号 

-f, -force: 强制删除镜像, 即使有容器依赖它。

总之, 通常并不推荐使用-f参数来强制删除一个存在容器依赖的镜像。 正确的做法是,先删除依赖该镜像的所有容器, 再来删除镜像。  

二、Docker容器

容器是Docker的另一个核心概念。简单来说,容器是镜像的一个运行实例。所不同的是,镜像是静态的只读文件,而容器带有运行时需要的可写文件层;同时,容器中的应用进程处于运行状态。

通俗理解:类 -> 实例,镜像 -> 容器

创建容器 

  1. # 方式一:创建容器不指定容器名,由Docker容器随机生成
  2. docker create -it centos:latest
  3. # 方式二:创建容器并指定容器名
  4. docker create -it --name tomcat01 centos:latest

命令说明:

命令说明
create创建docker容器关键字
-it是两个参数,-i:interactive容器具有交互功能,-t:容器将提供伪终端
--name指定生成的容器的名字,允许空,如果不指定会自动生成
centos:latest即镜像名字:版本(或镜像ID),将使用指定镜像创建容器。另外,Docker会检查本地是否存在指定的镜像,不存在就从公有仓库下载。

查看容器

查看当前运行的容器:

docker ps

查看所有容器:

docker ps -a

启停容器

  1. # 启动容器
  2. docker start 容器ID或name
  3. # 停止容器
  4. docker stop 容器ID或name
  5. # 重启容器
  6. docker restart 容器ID或name

删除容器

docker rm 容器ID

主要支持的选项包括:

选项说明
-f, --force=false是否强行终止并删除一个运行中的容器
-l, --link=false删除容器的连接 ,但保留容器
-v, --volumes=false删除容器挂载的数据卷

删除所有未运行的容器(已经运行的删除不了,未运行的就一起被删除了)

docker rm $(docker ps -aq)

停止所有容器并删除容器:

docker stop $(docker ps -aq) && docker rm $(docker ps -aq)

还可以根据容器的状态删除,删除Exited状态的容器:

docker rm $(docker ps -qf status=exited)

Docker 1.13版本以后,可以使用 docker containers prune 命令,删除孤立的容器:

docker container prune

进入容器

  1. docker exec -it 容器ID/容器NAME /bin/bash
  2. # 简写方式:
  3. docker exec -it 容器ID/容器NAME bash

 注意:只有在容器启动的时候即UP状态才能进入容器终端

创建/启动/进入容器

run 命令等于 create + start。

  • 创建+启动+进入容器:

    docker run -it centos:latest /bin/bash
  • 创建容器,通过 -p 标记指定端口映射规则,可以指定多个:(注意:此处p是小写)

    docker run -it -p 7001:8001 centos:latest /bin/bash

  • 使用 -P 标记时, Docker 会随机映射一个 49000~49900 的端口:(注意:此处P是大写)

    docker run -it -P --name tomcat03 centos:latest /bin/bash

更多的时候,需要让 Docker 容器在后台以守护态( Daemonized )形式运行 此时,可以通过添加 -d 参数来实现:

  1. # 创建容器指定后台运行模式(后台守护态)
  2. docker run -it -d --name webapp centos:latest
  3. # 进入容器
  4. docker exec -it webapp /bin/bash

部分参数说明:

参数说明
-p端口映射,格式为:主机(宿主)端口:容器端口
-P注意是大写P,使用 -P 标记时,Docker 会随机映射一个 49000~49900 的端口
-d后台运行模式

退出容器

退出时如果想继续运行容器:按顺序按【ctrl+p】,【ctrl+q】

如果不想继续运行:按【ctrl+d】或输入exit

查看容器内部信息

  • 进入容器内部获取信息

首先,请先进入容器:

docker exec -it 容器ID/容器NAME /bin/bash

如果此时已进入容器内部,可分别执行hostname、ip addr、env这三个命令可以获取相关信息:

  1. # 查看主机名
  2. hostname
  3. # 查看IP地址
  4. ip addr
  5. # 查看环境变量
  6. env

  • 在宿主机,执行docker exec命令
  1. # 获取容器的hostname
  2. docker exec 容器ID/容器NAME hostname
  3. # 获取容器ip地址
  4. docker exec 容器ID/容器NAME ip addr
  5. # 获取容器环境变量
  6. docker exec 容器ID/容器NAME env
  • 在宿主机,使用 docker inspect 命令

推荐使用 docker inspect 来获取信息,这个命令会返回一个 json 字符串,里面以 key-value 的格式准备了该容器相关的信息,内容十分丰富,可以一次性取得全部内容,也可以返回指定 key 对应的信息。

docker inspect 容器ID/容器NAME

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/627385
推荐阅读
相关标签
  

闽ICP备14008679号