一、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