Docker入门及基本概念

ops/2025/2/24 21:13:16/

让我们从最基础的概念开始逐步理解。假设你已经准备好了docker 环境。

第一步,让我们先通过实际操作来看看当前系统中的镜像(images)和容器(containers)状态:

docker images    # 查看所有镜像
docker ps -a     # 查看所有容器(包括未运行的)

输出结果:

REPOSITORY                 TAG       IMAGE ID       CREATED       SIZE
linqiu1199/trae2api        v1.0.1    0d72ae59193b   4 days ago    20.4MB
rustdesk/rustdesk-server   latest    9227b43758be   4 weeks ago   12.8MB
mysql                      latest    3e34946bc4c4   4 weeks ago   797MB
hello-world                latest    74cc54e27dc4   4 weeks ago   10.1kB
redis                      latest    fa310398637f   6 weeks ago   117MB
[root@localhost ~]# docker ps -a
CONTAINER ID   IMAGE                             COMMAND                   CREATED        STATUS                    PORTS                                                  NAMES
4fa63eb76d16   linqiu1199/trae2api:v1.0.1        "./main"                  16 hours ago   Up 3 hours                0.0.0.0:17080->17080/tcp, :::17080->17080/tcp          trae2api
25e6b341f3cb   rustdesk/rustdesk-server:latest   "hbbs"                    10 days ago    Exited (0) 18 hours ago                                                          hbbs
239edf233492   rustdesk/rustdesk-server:latest   "hbbr"                    10 days ago    Exited (0) 18 hours ago                                                          hbbr
84fbae57a78c   redis                             "docker-entrypoint.s…"   12 days ago    Up 3 hours                0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              redis
48b0ee678e43   mysql                             "docker-entrypoint.s…"   12 days ago    Up 3 hours                0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql
[root@localhost ~]# 

镜像(Images)和容器(Containers)的关系:

举一个很好的例子 - redis:

镜像:您系统中有一个 redis (latest) 镜像,大小为 117MB
容器:基于这个镜像运行了一个容器(ID: 84fbae57a78c),正在运行中(Status: Up 3 hours)

让我们通过一个实际操作来理解这个关系。我建议执行以下命令来创建另一个 redis 容器

docker run --name redis-test -d redis

执行这个命令,然后再次运行:

docker ps -a
  • 同一个镜像可以创建多个容器
  • 每个容器都是镜像的运行实例

有点类似与JavaSE 中的 类和对象,让我用面向对象的概念来进一步解释:

镜像(Image) => 类(Class)

  • 是一个模板
  • 包含了所有必要的代码和依赖
  • 是只读的
  • 可以被多次使用来创建不同的容器
  • 不能直接运行,需要实例化成容器

容器(Container) => 对象(Object)

  • 是镜像的运行实例
  • 有自己的状态和数据
  • 可以启动、停止、删除
  • 多个容器可以基于同一个镜像创建
  • 每个容器都是独立的运行环境

让我们通过实际操作来验证这个概念:

# 基于同一个 redis 镜像再创建一个容器,但使用不同的名字和端口
docker run --name redis-test2 -d -p 6380:6379 redis
  • 执行这个命令的时候,你是否会有这样的疑惑呢?由于之前在Docker装过了redis,在主机端口,设置了6380, 这样避开了6379 端口。是考虑到的,但是 容器端口 还是 6379 这样合理吗?

答: 这里的关键点是:

  1. 容器完全隔离的环境,每个容器都有自己的网络空间
  2. 不同容器可以使用相同的内部端口(6379)
  3. 宿主机的端口不能重复

然后查看结果:

docker ps -a | grep redis
oot@localhost ~]# docker ps -a | grep redis
a31ec1598cf9   redis                             "docker-entrypoint.s…"   9 seconds ago   Up 8 seconds              0.0.0.0:6380->6379/tcp, :::6380->6379/tcp              redis-test2
84fbae57a78c   redis                             "docker-entrypoint.s…"   12 days ago     Up 4 hours                0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              redis
[root@localhost ~]# 

执行后,应该能看到多个 redis 容器(对象),但它们都是基于同一个 redis 镜像(类)创建的。

docker_run__docker_start_89">docker run & docker start

  1. 先查看当前系统中所有的容器状态,包括已停止的容器。请执行以下命令:
docker ps -a 
[root@localhost ~]# docker ps -a
CONTAINER ID   IMAGE                             COMMAND                   CREATED         STATUS                    PORTS                                                  NAMES
a31ec1598cf9   redis                             "docker-entrypoint.s…"   5 minutes ago   Up 5 minutes              0.0.0.0:6380->6379/tcp, :::6380->6379/tcp              redis-test2
4fa63eb76d16   linqiu1199/trae2api:v1.0.1        "./main"                  16 hours ago    Up 4 hours                0.0.0.0:17080->17080/tcp, :::17080->17080/tcp          trae2api
25e6b341f3cb   rustdesk/rustdesk-server:latest   "hbbs"                    10 days ago     Exited (0) 18 hours ago                                                          hbbs
239edf233492   rustdesk/rustdesk-server:latest   "hbbr"                    10 days ago     Exited (0) 18 hours ago                                                          hbbr
84fbae57a78c   redis                             "docker-entrypoint.s…"   12 days ago     Up 4 hours                0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              redis
48b0ee678e43   mysql                             "docker-entrypoint.s…"   12 days ago     Up 4 hours                0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql
[root@localhost ~]#
  1. 下一步,我们将使用 docker run 命令来创建一个新的容器。请执行以下命令:
docker run --name new-redis -d -p 6381:6379 redis

这个命令会基于 redis 镜像创建并启动一个新的容器

执行完后,请再次运行 docker ps -a,是否看到了一个名为 “new-redis” 的新容器,以及它的状态如何。

AINER ID   IMAGE                             COMMAND                   CREATED         STATUS                    PORTS                                                  NAMES
751466ad80a1   redis                             "docker-entrypoint.s…"   3 seconds ago   Up 2 seconds              0.0.0.0:6381->6379/tcp, :::6381->6379/tcp              new-redis
a31ec1598cf9   redis                             "docker-entrypoint.s…"   7 minutes ago   Up 7 minutes              0.0.0.0:6380->6379/tcp, :::6380->6379/tcp              redis-test2
4fa63eb76d16   linqiu1199/trae2api:v1.0.1        "./main"                  16 hours ago    Up 4 hours                0.0.0.0:17080->17080/tcp, :::17080->17080/tcp          trae2api
25e6b341f3cb   rustdesk/rustdesk-server:latest   "hbbs"                    10 days ago     Up About a minute                                                                hbbs
239edf233492   rustdesk/rustdesk-server:latest   "hbbr"                    10 days ago     Exited (0) 18 hours ago                                                          hbbr
84fbae57a78c   redis                             "docker-entrypoint.s…"   12 days ago     Up 4 hours                0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              redis
48b0ee678e43   mysql                             "docker-entrypoint.s…"   12 days ago     Up 4 hours                0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql
[root@localhost ~]# 

总结一下关键点:

  1. docker start (我们用在 hbbs 容器上):

    1. 启动了一个已存在但停止的容器
    2. 没有创建新的容器
    3. 容器 ID 和名称保持不变

  1. docker run (我们用来创建 new-redis):

    1. 创建了一个全新的容器 (ID: 751466ad80a1)
    2. 自动启动了这个新容器
    3. 使用了我们指定的名称 (new-redis)
    4. 映射了新的端口 (6381)

下一步,让我们更深入地理解这两个命令的使用场景。请尝试以下操作:

  1. 停止 new-redis 容器
docker stop new-redis
  1. 然后尝试使用 docker run 再次创建一个同名的容器
docker run --name new-redis -d -p 6381:6379 redis
[root@localhost ~]# docker run --name new-redis -d -p 6381:6379 redis
docker: Error response from daemon: Conflict. The container name "/new-redis" is already in use by container "751466ad80a1e95003b7df5370ec4657c95e6dab87b927e7ea01104ed8aa2081". You have to remove (or rename) that container to be able to reuse that name.
See 'docker run --help'.
[root@localhost ~]#
  • docker run 尝试创建一个新容器,但失败了。
  • 错误原因是容器名 “new-redis” 已经被使用。
  • Docker建议我们要么移除旧容器,要么重命名,才能重用这个名字。

这个结果进一步说明了 docker rundocker start 的区别:

下一步,让我们尝试使用 docker start 来启动已停止的 new-redis 容器

docker start new-redis

在这里插入图片描述
成功运行!!


http://www.ppmy.cn/ops/161045.html

相关文章

postman调用ollama的api

按照如下设置,不需要设置key 保持长会话的方法 # 首次请求 curl http://localhost:11434/api/generate -d {"model": "deepseek-r1:32b","prompt": "请永久记住:110,1-12,之后所有数学计算必…

QT 基础知识点

1.基础窗口类QMainWindow qDialog Qwidget 随项目一起创建的窗口基类有三个可选QMainWindow qDialog Qwidget 1.1 Qwidget 是所有窗口的基类,只要是他的子类,或子类的子类,都具有他的属性。 右键项目 Add New -> Qt qt设计师界面类&am…

FTP 实验(ENSP模拟器实现)

FTP 概述 FTP(File Transfer Protocol,文件传输协议)是一种用于在网络上进行文件传输的标准协议。它允许用户在两台计算机之间上传和下载文件。 1、FTP采用客户端-服务器模型,客户端通过FTP客户端软件,连接到FTP服务…

重学SpringBoot3-Spring Retry实践

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞??收藏评论 重学SpringBoot3-Spring Retry实践 1. 简介2. 环境准备3. 使用方式 3.1 注解方式 基础使用自定义重试策略失败恢复机制重试和失败恢复效果注意事项 3.2 编程式使用3.3 监听重试过程 监…

计算机毕业设计SpringBoot+Vue.jst0甘肃非物质文化网站(源码+LW文档+PPT+讲解)

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

go json处理 encoding/json 查询和修改gjson/sjson

推荐 标准库encoding/json import ("encoding/json""log" )// Student1 注意点: // 1. 注意alain别名的写法: json:"name1" 而非 "json:name1" // 2. 注意json.Marshal的时候只输出首字母大写的属性 // 3. jso…

机器视觉--Halcon的数据结构(数组)

引言 在机器视觉领域,Halcon 作为一款功能强大且广泛应用的软件,其丰富的数据结构为开发者提供了高效处理各种视觉任务的能力。数组作为其中一种基础且重要的数据结构,在 Halcon 中扮演着不可或缺的角色。它能够有序地存储多个相同类型的数据…

鸿蒙NEXT应用App测试-通用测试

注意:大家记得学完通用测试记得再学鸿蒙专项测试 https://blog.csdn.net/weixin_51166786/article/details/145768653 注意:博主有个鸿蒙专栏,里面从上到下有关于鸿蒙next的教学文档,大家感兴趣可以学习下 如果大家觉得博主文章…