01 docker学习总结
https://docs.docker.com/engine/installation/mac/#from-your-shell
启动docker machine
[12:52:24] ahaomu:~ $ docker-machine ls
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
default - virtualbox Running tcp://192.168.99.100:2376 v1.10.2
machine02 - virtualbox Stopped
[12:53:06] ahaomu:~ $ docker-machine start default
[17:56:37] ahaomu:default $ docker run -d -P --name web nginx
docker run 启动一个container,运行它,-d 后台运行container,
-P:publishes exposed ports from the container to your local host
[21:05:11] ahaomu:machines $ docker run -t -i ubuntu /bin/bash
[21:05:23] ahaomu:machines $ docker run -d ubuntu /bin/sh -c "while true;do echo hello world;sleep 1;done”
docker ps
docker logs
docker stop
部署一个webapp
$ docker run -d -P training/webapp python app.py
-d 后台运行
-P 使得docker网络端口映射到主机上
training/webapp 这是一个镜像
docker ps 只显示running container
docker ps -l 显示最后一个container启动时的详情
docker ps -a 显示running 和stopped container都显示
docker run -P 显示所有container和host之间的映射端口关系
第一次执行需要下载,但是下载那么多什么东西呢?
[21:59:41] ahaomu:machines $ docker run -d -P training/webapp python app.py
Unable to find image 'training/webapp:latest' locally
latest: Pulling from training/webapp
e190868d63f8: Downloading [========> ] 11.35 MB/65.77 MB
909cd34c6fd7: Download complete
0b9bfabab7c1: Download complete
a3ed95caeb02: Download complete
10bbbc0fc0ff: Download complete
fca59b508e9f: Download complete
e7ae2541b15b: Download complete
9dd97ef58ce9: Download complete
e190868d63f8: Downloading [=========> ] 11.89 MB/65.77 MB
$ docker run -d -P training/webapp python app.py 其实这里的-P是 -p 5000的缩写
$ docker run -d -p 80:5000 training/webapp python app.py 其实这里的-p可以重新绑定端口映射关系,container里的port 5000 映射到local host的port 80
为什么我们不能container和host之间建立1:1 的端口映射关系呢?
官方回答:
Well 1:1 mappings have the constraint of only being able to map one of each port on your local host.
假如你有两个python app 的containner都使用port 5000,如果没有端口映射关系,那么你只能访问一个python app,这不好,如果两个都映射到一个host的port 49155,你在浏览器里可以看到两个。
docker ps 去看端口映射关系真是累啊,可以使用docker port 去看一个 container 的port映射到host的哪个端口
$ docker port nostalgic_morse 5000
0.0.0.0:49155
如何去看一个web application的log?
$ docker logs -f nostalgic_morse
如何去看一个web application container 里的process?
$ docker top nostalgic_morse
PID USER COMMAND
854 root python app.py
你会发现 python app.py 这个命令只是 这个container里的一个process进程。
$ docker inspect nostalgic_morse
指定一个container,返回一个JSON格式的配置configuration信息和状态status信息
$ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' nostalgic_morse
172.17.0.5
$ docker stop nostalgic_morse 表示关闭一个container
nostalgic_morse
$ docker ps -l 看看刚才的container是否被关闭
启动一个container?
$ docker start nostalgic_morse
nostalgic_morse
$ docker ps -l 看看刚才的container是否开启
我现在启动了好几个container,http://localhost:32770/ 为什么看不到东西呢?那是因为localhost是我的mac不是container的IP,你需要先知道container的IP地址,执行:
ahaomu:~ $ docker-machine ip default
192.168.99.100
[22:57:51] ahaomu:~ $ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4fe1a53bcfeb training/webapp "python app.py" 10 minutes ago Up 10 minutes 0.0.0.0:80->5000/tcp sleepy_feynman
add9c2815a6e training/webapp "python app.py" 11 minutes ago Up 11 minutes 0.0.0.0:32770->5000/tcp tiny_lamarr
9d2a20d1a824 training/webapp "python app.py" 12 minutes ago Up 12 minutes 0.0.0.0:32769->5000/tcp lonely_lichterman
1bc34c081946 training/webapp "python app.py" 26 minutes ago Up 26 minutes 0.0.0.0:32768->5000/tcp hungry_fermi

[22:57:40] ahaomu:~ $ docker-machine ip default
192.168.99.100
```
[23:05:06] ahaomu:machines $ docker-machine ls
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
default * virtualbox Running tcp://192.168.99.100:2376 v1.10.2
## 创建多个docker machine
[14:48:37] ahaomu:~ $ docker-machine create -d virtual box machine02
[14:50:45] ahaomu:~ $ docker-machine ls
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
machine02 - virtualbox Running tcp://192.168.99.101:2376 v1.10.2
[14:50:53] ahaomu:~ $ cd .docker/machine/machines/
default/ machine02/

现在我有多个docker machine,我该如何选择使用哪个呢?

问题来了,如果我host上只有一个docker machine,这个machine的ip如下,并且执行eval "$(docker-machine env default)” 配置我的host的shell,现在有两个