Docker的小白之路七(Docker使用篇之端口映射)

一、运行一个web应用

让我们尝试使用 docker 构建一个 web 应用程序。

我们将在docker容器中运行一个 Python Flask 应用来运行一个web应用。

# 拉取对应的镜像,速度有点慢
root@felaim-pc:/home/felaim/Documents/docker_tutorial# docker pull training/webapp
root@felaim-pc:/home/felaim/Documents/docker_tutorial# docker run -d -P training/webapp python app.py

参数说明:

  • -d:让容器在后台运行。
  • -P:将容器内部使用的网络端口映射到我们使用的主机上。

docker开放多个对外端口 docker -p 多个端口_网络

二、查看 WEB 应用容器

使用 docker ps 来查看我们正在运行的容器:

root@felaim-pc:/home/felaim/Documents/docker_tutorial# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED              STATUS              PORTS                     NAMES
ee3b67dfb4f7        training/webapp     "python app.py"     About a minute ago   Up About a minute   0.0.0.0:32768->5000/tcp   adoring_jackson

这里多了端口信息。

PORTS
0.0.0.0:32769->5000/tcp

Docker 开放了 5000 端口(默认 Python Flask 端口)映射到主机端口 32769 上。

这时我们可以通过浏览器访问WEB应用

docker开放多个对外端口 docker -p 多个端口_docker开放多个对外端口_02

我们也可以通过 -p 参数来设置不一样的端口:

root@felaim-pc:/home/felaim# docker run -d -p 5000:5000 training/webapp python app.py

docker开放多个对外端口 docker -p 多个端口_python_03


同样也会出现hello world,但是映射的端口改变为5000

docker开放多个对外端口 docker -p 多个端口_python_04

三、网络端口的快捷方式

通过 docker ps 命令可以查看到容器的端口映射,docker 还提供了另一个快捷方式 docker port,使用 docker port 可以查看指定 (ID 或者名字)容器的某个确定端口映射到宿主机的端口号。

上面我们创建的 web 应用容器 ID 为 2c921d2c425f 名字为 wizardly_matsumoto。

我可以使用 docker port 2c921d2c425f 或 docker port wizardly_matsumoto 来查看容器端口的映射情况。

docker开放多个对外端口 docker -p 多个端口_docker_05

四、查看 WEB 应用程序日志

docker logs [ID或者名字] 可以查看容器内部的标准输出。

root@felaim-pc:/home/felaim# docker logs -f 2c921d2c425f
 * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
×××× - - [01/Apr/2020 01:30:05] "GET / HTTP/1.1" 200 -
×××× - - [01/Apr/2020 01:30:05] "GET /favicon.ico HTTP/1.1" 404 -

-f: 让 docker logs 像使用 tail -f 一样来输出容器内部的标准输出。

从上面,我们可以看到应用程序使用的是 5000 端口并且能够查看到应用程序的访问日志。

五、查看WEB应用程序容器的进程

我们还可以使用 docker top 来查看容器内部运行的进程

root@felaim-pc:/home/felaim# docker top 2c921d2c425f
UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                9941                9909                0                   09:27               ?                   00:00:00            python app.py

六、检查 WEB 应用程序

使用 docker inspect 来查看 Docker 的底层信息。它会返回一个 JSON 文件记录着 Docker 容器的配置和状态信息。

说实话,这一段我就没有很看的懂了,等后续需要再研究Docker容器的配置等问题,LZ再看吧。。。

root@felaim-pc:/home/felaim# docker inspect  2c921d2c425f
[
    {
        "Id": "2c921d2c425fb9982470bc52c02edfc4e5a6cb7c3a3ccc5e2e2e548c43dbd61c",
        "Created": "2020-04-01T01:27:19.189429856Z",
        "Path": "python",
        "Args": [
            "app.py"
        ],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 9941,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2020-04-01T01:27:21.175629699Z",
            "FinishedAt": "0001-01-01T00:00:00Z"
        },
        "Image": 
        ...
    }
]

七、停止 WEB 应用程序

root@felaim-pc:/home/felaim# docker stop  2c921d2c425f

docker开放多个对外端口 docker -p 多个端口_docker_06

八、重启WEB应用容器

已经停止的容器,我们可以使用命令 docker start 来启动。

root@felaim-pc:/home/felaim# docker start  2c921d2c425f

docker开放多个对外端口 docker -p 多个端口_python_07


docker ps -l 查询最后一次创建的容器:

root@felaim-pc:/home/felaim# docker ps -l

docker开放多个对外端口 docker -p 多个端口_docker_08

九、移除WEB应用容器

我们可以使用 docker rm 命令来删除不需要的容器

root@felaim-pc:/home/felaim# docker rm  2c921d2c425f

删除容器时,容器必须是停止状态,否则会报如下错误

root@felaim-pc:/home/felaim# docker rm  2c921d2c425f
Error response from daemon: You cannot remove a running container 2c921d2c425fb9982470bc52c02edfc4e5a6cb7c3a3ccc5e2e2e548c43dbd61c. Stop the container before attempting removal or force remove

使用docker stop暂停后,再使用docker rm删除容器,最后使用docker ps -a发现容器已经成功删除!

docker开放多个对外端口 docker -p 多个端口_python_09


其实这个例子最重要的并不是说怎么使用这个webapp,而是其中一个比较重要的技术是端口映射的问题,这个对于后续使用docker进行远程操作是非常重要的一个知识点。