前言

大家好,本文是对 Docker 容器的详细讲解,讲解了如何启动容器、进入容器,以及操作容器的命令。希望对大家有所帮助~

目录

    • 前言
    • 一、Docker 容器 – 操作 Docker 容器
        • 1、启动容器
        • 2、新建并启动容器
        • 3、启动已终止容器
        • 4、守护态运行
        • 5、终止容器
        • 6、进入容器
        • 7、attach 命令
        • 8、exec 命令
          • 8.1、 -i -t 参数

一、Docker 容器 – 操作 Docker 容器

容器是 Docker 又一核心概念。

简单的说,容器是独立运行的一个或一组应用,以及它们的运行态环境。对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用。

1、启动容器

启动容器有两种方式,一种是基于镜像新建一个容器并启动,另外一个是将在终止状态(stopped)的容器重新启动。

2、新建并启动容器

所需要的命令主要为 docker run

例如,下面的命令输出一个 “Hello World” ,之后终止容器。

docker run ubuntu:18.04 /bin/echo 'Hello World'Hello World

这跟在本地直接执行 /bin/echo 'hello world' 几乎感觉不出任何区别。

下面的命令则启动一个 bash 终端,允许用户进行交互。

docker run -t -i ubuntu:18.04 /bin/bashroot@af8bae53bdd3:/#

其中,-t 选项让 Docker 分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上,-i 则让容器的标准输入保持打开。

在交互模式下,用户可以通过所创建的终端来输入命令,例如

root@af8bae53bdd3:/# pwd/root@af8bae53bdd3:/# lsbin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var

当利用 docker run 来创建容器时,Docker 在后台运行的标准操作包括:

  • 检查本地是否存在指定镜像,不存在就从共有仓库下载
  • 利用镜像创建并启动一个容器
  • 分配一个文件系统,并在只读的镜像层外面挂在一层可读写层
  • 从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去
  • 从地址池配置一个 ip 地址给容器
  • 执行用户指定的应用程序
  • 执行完毕后容器被终止

3、启动已终止容器

可以利用 docker container start 命令,直接将一个已经终止的容器启动运行。

容器的核心为所执行的应用程序,所需要的资源都是应用程序运行所必需的。除此之外,并没有其他资源。可以在伪终端中利用 pstop 来查看进程信息。

root@af8bae53bdd3:/# psPID TTYTIME CMD1 ?00:00:00 bash 11 ?00:00:00 ps

可见,容器中仅运行了指定的 bash 应用。这种特点使得 Docker 对资源的利用率极高,是货真价实的轻量级虚拟化。

4、守护态运行

更多时候,需要让 Docker 在后台运行而不是直接把执行命令的结果输出在当前宿主机下。此时,可以通过添加 -d 参数来实现。

下面举两个例子来说明一下。

如果不使用 -d 参数运行容器。

$ docker run ubuntu:18.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"hello worldhello worldhello worldhello world

容器会把输出的结果(STDOUT)打印到宿主机上面

如果使用了 -d 参数运行容器。

$ docker run -d ubuntu:18.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"264ff93e690b5314fc3d67c06c578b01299a090eca1e80ab5785300d24f11612

此时容器会在后台运行并不会把输出结果(STDOUT)打印到宿主机上面(输出结果可以用 docker logs 查看)。

注: 容器是否会长久运行,是和 docker run 指定的命令有关,和 -d 参数无关。

使用 -d 参数启动后会返回一个唯一的 id,也可以通过 docker container ls 命令来查看容器信息。

$ docker container lsCONTAINER IDIMAGE COMMANDCREATED STATUSPORTSNAMES264ff93e690bubuntu:18.04"/bin/sh -c 'while t…" 14 seconds agoUp 13 secondseager_goldberg

要获取容器的输出信息,可以通过 docker container logs 命令。

$ docker container logs [containerId or NAMES]# 例如:$ docker container logs 264ff93e690bhello worldhello worldhello world. . .

5、终止容器

可以使用 docker container stop 来终止一个运行中的容器。

此外,当 Docker 容器中指定的应用终结时,容器也自动终止。

例如只启动了一个终端的容器,用户通过 exit 命令或 Ctrl+d 来退出终端时,所创建的容器立刻终止。

终止状态的容器可以用 docker container ls -a 命令看到。例如:

$ docker container ls -aCONTAINER IDIMAGE COMMANDCREATED STATUS PORTSNAMES264ff93e690bubuntu:18.04"/bin/sh -c 'while t…" 2 minutes ago Up 2 minuteseager_goldberg3c45ebb4c80bubuntu:18.04"/bin/sh -c 'while t…" 2 minutes ago Up 2 minutespractical_gagari

对于终止状态的容器,可以通过 docker container start 命令来重新启动。

此外,docker container restart 命令会将一个运行状态的容器终止,然后再重新启动它。

6、进入容器

在使用 -d 参数时,容器启动后会进入后台。

某些时候需要进入容器进行操作,包括使用 docker attach 命令或 docker exec 命令,推荐大家使用 docker exec 命令,原因会在下面说明。

7、attach 命令

docker attachDocker 自带的命令。下面示例如何使用该命令。

$ docker run -dit ubuntu77b458b98ecb6b89c7acbfbe83497a6eff6dab9d76bf8c0600c331fccb8f1803$ docker container lsCONTAINER IDIMAGE COMMAND CREATED STATUSPORTS NAMESa31d8dd20fa6ubuntu"bash"16 seconds agoUp 16 seconds nostalgic_noether$ docker attach a31droot@a31d8dd20fa6:/# 

进入容器后,如果执行 exit,会导致容器的停止。

8、exec 命令

8.1、 -i -t 参数

docker exec 后边可以跟多个参数,这里主要说明 -i -t 参数。

只用 -i 参数时,由于没有分配伪终端,界面没有我们熟悉的 Linux 命令提示符,但命令执行结果仍然可以返回。

-i -t 参数一起使用时,则可以看都我们熟悉的Linux命令提示符。

$ docker run -dit ubuntu4a31d9ca418520453ff890173731d61953a8c818014c0f8681b6d48362a92250$ docker container lsCONTAINER IDIMAGE COMMAND CREATED STATUSPORTS NAMES4a31d9ca4185ubuntu"bash"25 seconds agoUp 24 seconds brave_brownroot@ubuntu:~# docker exec -i 4a31 bashlsbinbootdevetchomeliblib32lib64libx32mediamntoptprocrootrunsbinsrvsystmpusrvar$ docker exec -it 4a31 /bin/bashroot@4a31d9ca4185:/# 

进入容器后,如果执行 exit,不会导致容器的停止。这就是为什么推荐使用 docker exec 的原因。

更多参数说明请使用 docker exec --help 查看。

读到这里,想必你已经熟悉了如何的去启动容器、进入容器,以及操作容器。别忘了三连支持博主呀~
我是微枫Micromaple,期待你的关注~