一、Docker客户端:
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker
输入docker命令来查看到Docker客户端的所有命令选项
可以通过命令 docker命令--help 更深入的了解指定的Docker命令使用方法。
1.运行一个网络应用:
〜#docker pull training/webapp 载入镜像
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker run -d -P training/webapp python app.py
- -d:让容器在后台运行。
- -P:将容器内部使用的网络端口映射到我们使用的主机上。
2.查看WEB应用容器
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
bb51b0a936af training/webapp "python app.py" 8 minutes ago Up 7 minutes 0.0.0.0:32768->5000/tcp inspiring_elbakyan
Docker开放了5000端口(默认Python Flask端口)映射到主机端口32769上。
这时我们可以通过浏览器访问WEB应用
http://172.20.200.219:32768/ 上可以看到Hello world!
我们也可以通过-p参数来设置不一样的端口:
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker run -d -p 5000:5000 training/webapp python app.py
642ca47f644571843bfba0f9bcd8943eae5e4e644ab4318f858c90c76aa924ce
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
642ca47f6445 training/webapp "python app.py" 12 seconds ago Up 10 seconds 0.0.0.0:5000->5000/tcp affectionate_mccarthy
bb51b0a936af training/webapp "python app.py" 33 minutes ago Up 33 minutes 0.0.0.0:32768->5000/tcp inspiring_elbakyan
容器内部的5000端口映射到我们本地主机的5000端口上。
3.网络端口的快捷方式
通过docker ps命令可以查看容器的端口映射,docker还提供了另一个快捷方式:docker port,使用docker port可以查看指定(ID或者名字)容器的某个确定端口映射到宿主机的端口号。
上面我们创建的web应用容器ID为:642ca47f6445 名字为affectionate_mccarthy
我们可以使用以下方法来查看端口的映射情况
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker port 642ca47f6445
5000/tcp -> 0.0.0.0:5000
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker port affectionate_mccarthy
5000/tcp -> 0.0.0.0:5000
4.查看WEB应用程序日志
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker logs -f 642ca47f6445
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker logs -f affectionate_mccarthy
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
-f: 让 dokcer记录 像使用 tail -f 一样来输出容器内部的标准输出。
从上面,我们可以看到应用程序使用的是5000端口并且能够查看应用程序的访问日志。
5.查看WEB应用程序容器的进程
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker top affectionate_mccarthy
PID USER TIME COMMAND
5551 root 0:00 python app.py
6.检查WEB应用程序
使用Docker检查来查看Docker的底层信息。它会返回一个JSON文件记录Docker容器的配置和状态信息。
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker inspect affectionate_mccarthy
[
{
"Id": "642ca47f644571843bfba0f9bcd8943eae5e4e644ab4318f858c90c76aa924ce",
"Created": "2018-06-21T13:43:02.676109892Z",
"Path": "python",
"Args": [
"app.py"
],
"State": {
"Status": "running",
"Running": true,
"Paused": false,
"Restarting": false,
"OOMKilled": false,
"Dead": false,
"Pid": 5551,
"ExitCode": 0,
"Error": "",
"StartedAt": "2018-06-21T13:43:03.150933631Z",
"FinishedAt": "0001-01-01T00:00:00Z"
},
.....
7.停止WEB应用容器
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker stop affectionate_mccarthy
affectionate_mccarthy
docker ps -l查询最后一次创建的容器:
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker ps -l
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
642ca47f6445 training/webapp "python app.py" 17 minutes ago Exited (137) 39 seconds ago affectionate_mccarthy
8.重启WEB应用容器
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker start affectionate_mccarthy
affectionate_mccarthy
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker ps -l
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
642ca47f6445 training/webapp "python app.py" 19 minutes ago Up 3 seconds 0.0.0.0:5000->5000/tcp affectionate_mccarthy
9.移除WEB应用容器
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker rm affectionate_mccarthy
Error response from daemon: You cannot remove a running container 642ca47f644571843bfba0f9bcd8943eae5e4e644ab4318f858c90c76aa924ce. Stop the container before attempting removal or force remove
直接删除容器会发现报容器正在运行的错误,这是守护进程的错误响应,所有删除容器前要先stop它,正确操作:
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker stop affectionate_mccarthy
affectionate_mccarthy
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker rm affectionate_mccarthy
affectionate_mccarthy
leiyuxingdeMacBook-Pro:~ leiyuxing$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES