docker容器的使用
Posted jcjc
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了docker容器的使用相关的知识,希望对你有一定的参考价值。
Docker客户端
docker客户端非常简单,我们可以直接输入docker命令来查看到Docker客户端的所有命令选项。
[email protected] docker
可以通过命令docker command --help更深入的了解指定的Docker命令的使用方法。
例如我们查看docker stats 指令的具体使用方法:
[email protected]:~# docker stats --help
运行一个web应用
前面我们运行的容器并没有一些什么特别的用处。
接下来让我们尝试使用docker构建一个web应用来运行一个web应用。
[email protected]:~# docker pull training/webapp # 载入镜像 [email protected]:~# docker run -d -P training/webapp python app.py
参数说明
-d : 让容器在后台运行
-P:将容器内部使用的网络端口映射到我们使用的主机上。
查看WEB应用容器
使用docker ps来查看我们正在运行的容器:
[email protected]:~# docker ps CONTAINER ID IMAGE COMMAND ... PORTS d3d5e39ed9d3 training/webapp "python app.py" ... 0.0.0.0:32769->5000/tcp
这里多了端口信息。
PORTS 0.0.0.0:32769->5000/tcp
Docker开放了5000端口(默认 Python Flask 端口)映射到主机的32769上。
这时我们可以通过浏览器访问WEB应用
http://192.168.2.63:32768/
hello world
我们也可以通过 -p 参数设置不一样的端口:
[email protected]:~$ docker run -d -p 5000:5000 training/webapp python app.py
docker ps查看正在运行的容器:
[email protected]:~# docker ps CONTAINER ID IMAGE PORTS NAMES bf08b7f2cd89 training/webapp ... 0.0.0.0:5000->5000/tcp wizardly_chandrasekhar d3d5e39ed9d3 training/webapp ... 0.0.0.0:32769->5000/tcp xenodochial_hoov
容器内部的5000端口映射到我们本地的主机的5000端口上。
网络端口的快捷方式
通过docker ps 命令可以查看到容器的端口映射,docker还提供了另外一个快捷方式
docker port,使用docker port可以查看指定(ID或者名字)容器的某个确定端口映射
到宿主机的端口号。
上面我们创建的web应用容器ID为bf08b7f2cd89 名字改为wizardly_chandrasekhar。
我可以使用docker port bf08b7f2cd89 或 docker port wizardly_chandrasekhar来查看容器端口的映射情况。
[email protected]:~$ docker port bf08b7f2cd89 5000/tcp -> 0.0.0.0:5000
[email protected]:~$ docker port wizardly_chandrasekhar 5000/tcp -> 0.0.0.0:5000
查看WEB应用程序日志
docker logs [ID或者名字] 可以查看容器内部的标准输出。
[email protected]:~$ docker logs -f bf08b7f2cd89 * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit) 192.168.239.1 - - [09/May/2016 16:30:37] "GET / HTTP/1.1" 200 - 192.168.239.1 - - [09/May/2016 16:30:37] "GET /favicon.ico HTTP/1.1" 404 -
-f:让docker logs 像使用 tail -f 一样来输出容器内部的标准输出。
从上面,我们可以看到应用程序使用的是 5000 端口并且能够查看到应用程序的访问日志。
查看WEB应用程序容器的进程
我们还可以使用docker top 来查看容器内部运行的进程
[email protected]:~$ docker top wizardly_chandrasekhar UID PID PPID ... TIME CMD root 23245 23228 ... 00:00:00 python app.py
检查WEB应用程序
使用docker inspect 来查看 Docker 的底层信息。他会返回一个JDON文件记录着Docker容器的配置和状态信息。
[email protected]:~$ docker inspect wizardly_chandrasekhar [ { "Id": "bf08b7f2cd897b5964943134aa6d373e355c286db9b9885b1f60b6e8f82b2b85", "Created": "2018-09-17T01:41:26.174228707Z", "Path": "python", "Args": [ "app.py" ], "State": { "Status": "running", "Running": true, "Paused": false, "Restarting": false, "OOMKilled": false, "Dead": false, "Pid": 23245, "ExitCode": 0, "Error": "", "StartedAt": "2018-09-17T01:41:26.494185806Z", "FinishedAt": "0001-01-01T00:00:00Z" }, ......
停止WEB应用程序
[email protected]:~$ docker stop wizardly_chandrasekhar wizardly_chandrasekhar
重启WEB应用程序
已经停止的容器,我们可以使用命令 docker start wizardly_chandrasekhar来启动。
[email protected]:~$ docker start wizardly_chandrasekhar wizardly_chandrasekhar
docker ps -l 查询最后一次创建的容:
# docker ps -l CONTAINER ID IMAGE PORTS NAMES bf08b7f2cd89 training/webapp ... 0.0.0.0:5000->5000/tcp wizardly_chandrasekhar
移除WEB应用程序
我们可以使用docker rm命令来删除不需要的容器
[email protected]:~$ docker rm wizardly_chandrasekhar wizardly_chandrasekhar
删除容器时, 容器必须是停止状态,否则会报一下错误:
[email protected]:~$ docker rm wizardly_chandrasekhar Error response from daemon: You cannot remove a running container bf08b7f2cd897b5964943134aa6d373e355c286db9b9885b1f60b6e8f82b2b85. Stop the container before attempting removal or force remove
以上是关于docker容器的使用的主要内容,如果未能解决你的问题,请参考以下文章
无法使用 Rider 调试使用 docker 容器和 docker-compose 构建的 .net 核心应用程序。容器退出代码 139
Springboot 容器使用 docker-compose 连接到 mongo 容器的 503 错误代码