docker_practice/machine/usage.md

150 lines
4.5 KiB
Markdown
Raw Normal View History

2015-05-08 20:10:34 +08:00
## 使用
2015-07-16 15:34:54 +08:00
2017-12-03 18:26:10 +08:00
Docker Machine 支持多种后端驱动,包括虚拟机、本地主机和云平台等。
2015-07-16 15:34:54 +08:00
2017-12-03 18:26:10 +08:00
### 创建本地主机实例
2015-07-16 15:34:54 +08:00
2017-12-03 18:26:10 +08:00
#### Virtualbox 驱动
2017-12-03 14:33:46 +08:00
2017-11-23 01:22:25 +08:00
使用 `virtualbox` 类型的驱动,创建一台 Docker 主机,命名为 test。
```bash
2017-11-23 01:22:25 +08:00
$ docker-machine create -d virtualbox test
2015-07-16 15:34:54 +08:00
```
2017-12-03 14:33:46 +08:00
你也可以在创建时加上如下参数,来配置主机或者主机上的 Docker。
`--engine-opt dns=114.114.114.114` 配置 Docker 的默认 DNS
`--engine-registry-mirror https://registry.docker-cn.com` 配置 Docker 的仓库镜像
`--virtualbox-memory 2048` 配置主机内存
`--virtualbox-cpu-count 2` 配置主机 CPU
更多参数请使用 `docker-machine create --driver virtualbox --help` 命令查看。
#### macOS xhyve 驱动
`xhyve` 驱动 GitHub: https://github.com/zchee/docker-machine-driver-xhyve
[`xhyve`](https://github.com/mist64/xhyve) 是 macOS 上轻量化的虚拟引擎,使用其创建的 Docker Machine 较 `VirtualBox` 驱动创建的运行效率要高。
```bash
$ brew install docker-machine-driver-xhyve
$ docker-machine create \
-d xhyve \
# --xhyve-boot2docker-url ~/.docker/machine/cache/boot2docker.iso \
--engine-opt dns=114.114.114.114 \
--engine-registry-mirror https://registry.docker-cn.com \
--xhyve-memory-size 2048 \
--xhyve-rawdisk \
--xhyve-cpu-count 2 \
xhyve
```
>注意:非首次创建时建议加上 `--xhyve-boot2docker-url ~/.docker/machine/cache/boot2docker.iso` 参数,避免每次创建时都从 GitHub 下载 ISO 镜像。
更多参数请使用 `docker-machine create --driver xhyve --help` 命令查看。
2017-12-03 18:26:10 +08:00
#### Windows 10
2017-12-03 14:33:46 +08:00
Windows 10 安装 Docker for Windows 之后不能再安装 VirtualBox也就不能使用 `virtualbox` 驱动来创建 Docker Machine我们可以选择使用 `hyperv` 驱动。
> 注意,必须事先在 `Hyper-V` 管理器中新建一个 **外部虚拟交换机** 执行下面的命令时,使用 `--hyperv-virtual-switch=MY_SWITCH` 指定虚拟交换机名称
2017-12-03 14:33:46 +08:00
```bash
$ docker-machine create --driver hyperv --hyperv-virtual-switch=MY_SWITCH vm
2017-12-03 14:33:46 +08:00
```
更多参数请使用 `docker-machine create --driver hyperv --help` 命令查看。
2017-12-03 18:26:10 +08:00
### 使用介绍
2017-12-03 14:33:46 +08:00
创建好主机之后,查看主机
2017-11-23 01:22:25 +08:00
```bash
$ docker-machine ls
2017-11-23 01:29:38 +08:00
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
test - virtualbox Running tcp://192.168.99.187:2376 v17.10.0-ce
2017-11-23 01:22:25 +08:00
```
创建主机成功后,可以通过 `env` 命令来让后续操作对象都是目标主机。
```bash
2015-07-16 15:34:54 +08:00
$ docker-machine env test
```
2017-11-23 01:22:25 +08:00
后续根据提示在命令行输入命令之后就可以操作 test 主机。
也可以通过 `SSH` 登录到主机。
```bash
$ docker-machine ssh test
docker@test:~$ docker --version
Docker version 17.10.0-ce, build f4ffd25
```
2017-12-03 14:33:46 +08:00
连接到主机之后你就可以在其上使用 Docker 了。
2017-11-23 01:35:38 +08:00
### 官方支持驱动
2017-11-23 01:22:25 +08:00
2015-07-16 15:34:54 +08:00
通过 `-d` 选项可以选择支持的驱动类型。
2017-11-23 01:22:25 +08:00
2015-07-16 15:34:54 +08:00
* amazonec2
* azure
* digitalocean
* exoscale
* generic
* google
2017-12-03 14:33:46 +08:00
* hyperv
2015-07-16 15:34:54 +08:00
* none
* openstack
* rackspace
* softlayer
* virtualbox
* vmwarevcloudair
2017-12-03 14:33:46 +08:00
* vmwarefusion
2015-07-16 15:34:54 +08:00
* vmwarevsphere
2017-11-23 01:35:38 +08:00
### 第三方驱动
请到 [第三方驱动列表](https://github.com/docker/docker.github.io/blob/master/machine/AVAILABLE_DRIVER_PLUGINS.md) 查看
2015-07-16 15:34:54 +08:00
### 操作命令
2017-11-23 01:22:25 +08:00
2015-07-16 15:34:54 +08:00
* `active` 查看活跃的 Docker 主机
* `config` 输出连接的配置信息
* `create` 创建一个 Docker 主机
* `env` 显示连接到某个主机需要的环境变量
* `inspect` 输出主机更多信息
* `ip` 获取主机地址
* `kill` 停止某个主机
* `ls` 列出所有管理的主机
2017-11-23 01:22:25 +08:00
* `provision` 重新设置一个已存在的主机
2015-07-16 15:34:54 +08:00
* `regenerate-certs` 为某个主机重新生成 TLS 认证信息
* `restart` 重启主机
* `rm` 删除某台主机
* `ssh` SSH 到主机上执行命令
* `scp` 在主机之间复制文件
2017-11-23 01:22:25 +08:00
* `mount` 挂载主机目录到本地
2015-07-16 15:34:54 +08:00
* `start` 启动一个主机
2017-11-23 01:22:25 +08:00
* `status` 查看主机状态
2015-07-16 15:34:54 +08:00
* `stop` 停止一个主机
* `upgrade` 更新主机 Docker 版本为最新
* `url` 获取主机的 URL
2017-11-23 01:22:25 +08:00
* `version` 输出 docker-machine 版本信息
* `help` 输出帮助信息
2015-07-16 15:34:54 +08:00
每个命令,又带有不同的参数,可以通过
2017-11-23 01:22:25 +08:00
```bash
2017-11-23 01:27:16 +08:00
$ docker-machine COMMAND --help
2015-07-16 15:34:54 +08:00
```
2017-12-03 14:33:46 +08:00
2015-07-16 15:34:54 +08:00
来查看具体的用法。