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

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:將容器內部使用的網絡端口映射到我們使用的主機上。

在這裏插入圖片描述

二、查看 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應用
在這裏插入圖片描述我們也可以通過 -p 參數來設置不一樣的端口:

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

在這裏插入圖片描述
同樣也會出現hello world,但是映射的端口改變爲5000

在這裏插入圖片描述

三、網絡端口的快捷方式

通過 docker ps 命令可以查看到容器的端口映射,docker 還提供了另一個快捷方式 docker port,使用 docker port 可以查看指定 (ID 或者名字)容器的某個確定端口映射到宿主機的端口號。

上面我們創建的 web 應用容器 ID 爲 2c921d2c425f 名字爲 wizardly_matsumoto。

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

在這裏插入圖片描述

四、查看 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

在這裏插入圖片描述

八、重啓WEB應用容器

已經停止的容器,我們可以使用命令 docker start 來啓動。

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

在這裏插入圖片描述
docker ps -l 查詢最後一次創建的容器:

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

在這裏插入圖片描述

九、移除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發現容器已經成功刪除!
在這裏插入圖片描述
其實這個例子最重要的並不是說怎麼使用這個webapp,而是其中一個比較重要的技術是端口映射的問題,這個對於後續使用docker進行遠程操作是非常重要的一個知識點。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章