上篇文章Docker(四):Docker 三剑客之 Docker Compose 介绍了 Docker Compose,这篇文章我们来了解 Docker Machine 。

Docker Machine 介绍

Docker Machine 是 Docker 官方编排(Orchestration)项目之一,负责在多种平台上快速安装 Docker 环境。

Docker Machine 是一个工具,它允许你在虚拟宿主机上安装 Docker Engine ,并使用 docker-machine 命令管理这些宿主机。你可以使用 Machine 在你本地的 Mac 或 Windows box、公司网络、数据中心、或像 AWS 或 Digital Ocean 这样的云提供商上创建 Docker 宿主机。

使用 docker-machine 命令,你可以启动、审查、停止和重新启动托管的宿主机、升级 Docker 客户端和守护程序、并配置 Docker 客户端与你的宿主机通信。

为什么要使用它?

Docker Machine 使你能够在各种 Linux 上配置多个远程 Docker 宿主机。 
此外,Machine 允许你在较早的 Mac 或 Windows 系统上运行 Docker,如上一主题所述。 
Docker Machine 有这两个广泛的用例。

  • 我有一个较旧的桌面系统,并希望在 Mac 或 Windows 上运行 Docker

如果你主要在不符合新的 Docker for Mac 和 Docker for Windows 应用程序的旧 Mac 或 Windows 笔记本电脑或台式机上工作,则需要 Docker Machine 来在本地“运行Docker”(即Docker Engine)。在 Mac 或 Windows box 中使用 Docker Toolbox 安装程序安装 Docker Machine 将为 Docker Engine 配置一个本地的虚拟机,使你能够连接它、并运行 docker 命令。

  • 我想在远程系统上配置 Docker 宿主机

Docker Engine Linux 系统上原生地运行。如果你有一个 Linux 作为你的主系统,并且想要运行 docker 命令,所有你需要做的就是下载并安装 Docker Engine 。然而,如果你想要在网络上、云中甚至本地配置多个 Docker 宿主机有一个有效的方式,你需要 Docker Machine。

无论你的主系统是 Mac、Windows 还是 Linux,你都可以在其上安装 Docker Machine,并使用 docker-machine 命令来配置和管理大量的 Docker 宿主机。它会自动创建宿主机、在其上安装 Docker Engine 、然后配置 docker 客户端。每个被管理的宿主机(“machine”)是 Docker 宿主机和配置好的客户端的结合。

Docker Engine 和 Docker Machine 有什么区别?

当人们说“Docker”时,他们通常是指 Docker Engine,它是一个客户端 - 服务器应用程序,由 Docker 守护进程、一个REST API指定与守护进程交互的接口、和一个命令行接口(CLI)与守护进程通信(通过封装REST API)。Docker Engine 从 CLI 中接受docker 命令,例如 docker run 、docker ps 来列出正在运行的容器、docker images 来列出镜像,等等。

Docker Machine 是一个用于配置和管理你的宿主机(上面具有 Docker Engine 的主机)的工具。通常,你在你的本地系统上安装 Docker Machine。Docker Machine有自己的命令行客户端 docker-machine 和 Docker Engine 客户端 docker。你可以使用 Machine 在一个或多个虚拟系统上安装 Docker Engine。

这些虚拟系统可以是本地的(就像你在 Mac 或 Windows 上使用 Machine 在 VirtualBox 中安装和运行 Docker Engine 一样)或远程的(就像你使用 Machine 在云提供商上 provision Dockerized 宿主机一样)。Dockerized 宿主机本身可以认为是,且有时就称为,被管理的“machines”。

安装和使用

Docker Machine 安装很简单

curl -L https://github.com/docker/machine/releases/download/v0.14.0/docker-machine-`uname -s`-`uname -m` >/tmp/docker-machine && \
install /tmp/docker-machine /usr/local/bin/docker-machine#完成后,查看版本信息。
docker-machine -v
docker-machine version 0.14.0, build 89b8332
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

创建一个 VirtualBox

查看是否存在可用的主机

$  docker-machine ls
NAME   ACTIVE   DRIVER   STATE   URL   SWARM   DOCKER   ERRORS
  • 1
  • 2

创建一个主机:

$ docker-machine create --driver virtualbox default
Running pre-create checks...
(default) Default Boot2Docker ISO is out-of-date, downloading the latest release...
(default) Latest release for github.com/boot2docker/boot2docker is v17.12.1-ce
(default) Downloading C:\Users\hkrt-neo\.docker\machine\cache\boot2docker.iso from https://github.com/boot2docker/boot2docker/releases/download/v17.12.1-ce/boot2docker.iso...
(default) 0%....10%....20%....30%....40%....50%....60%....70%....80%....90%....100%
Creating machine...
(default) Copying C:\Users\hkrt-neo\.docker\machine\cache\boot2docker.iso to C:\Users\hkrt-neo\.docker\machine\machines\default\boot2docker.iso...
(default) Creating VirtualBox VM...
(default) Creating SSH key...
(default) Starting the VM...
(default) Check network to re-create if needed...
(default) Windows might ask for the permission to configure a dhcp server. Sometimes, such confirmation window is minimized in the taskbar.
(default) Waiting for an IP...
Waiting for machine to be running, this may take a few minutes...
Detecting operating system of created instance...
Waiting for SSH to be available...
Detecting the provisioner...
Provisioning with boot2docker...
Copying certs to the local machine directory...
Copying certs to the remote machine...
Setting Docker configuration on the remote daemon...
...
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

这个命令会下载 boot2docker,基于 boot2docker 创建一个虚拟主机。boot2docker 是一个轻量级的 linux 发行版,基于专门为运行 docker 容器而设计的 Tiny Core Linux 系统,完全从 RAM 运行,45Mb左右,启动时间约5s。

再次查看服务列表

docker-machine ls
NAME      ACTIVE   DRIVER       STATE     URL                         SWARM   DOCKER        ERRORS
default   *        virtualbox   Running   tcp://192.168.99.100:2376           v17.12.1-ce
  • 1
  • 2
  • 3

发现已经存在一个虚拟主机

创建主机成功后,可以通过 env 命令来让后续操作对象都是目标主机。

$ docker-machine env default
export DOCKER_TLS_VERIFY="1"
export DOCKER_HOST="tcp://192.168.99.100:2376"
export DOCKER_CERT_PATH="C:\Users\hkrt-neo\.docker\machine\machines\default"
export DOCKER_MACHINE_NAME="default"
export COMPOSE_CONVERT_WINDOWS_PATHS="true"
# Run this command to configure your shell:
# eval $("D:\Program Files\Docker Toolbox\docker-machine.exe" env default)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

相当于配置了一个环境变量 default,后续根据提示在命令行输入命令之后就可以操作 default 主机。

可以通过 SSH 登录到主机

$ docker-machine ssh defaultdocker@default:~$ docker --version
Docker version 17.12.1-ce, build 7390fc6
  • 1
  • 2
  • 3
  • 4

连接到主机之后你就可以在其上使用 Docker 了,退出虚拟机使用命令:exit

Docker Machine 常用命令

//创建虚拟机
docker-machine create [OPTIONS] [arg...]//移除虚拟机
docker-machine rm [OPTIONS] [arg...]//登录虚拟机
docker-machine ssh [arg...]//docker客户端配置环境变量
docker-machine env [OPTIONS] [arg...]//检查机子信息
docker-machine inspect//查看虚拟机列表
docker-machine ls [OPTIONS] [arg...]//查看虚拟机状态
docker-machine status [arg...]  //一个虚拟机名称//启动虚拟机
docker-machine start [arg...]  //一个或多个虚拟机名称//停止虚拟机
docker-machine stop [arg...]  //一个或多个虚拟机名称//重启虚拟机
docker-machine restart [arg...]  //一个或多个虚拟机名称
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

更多参数请使用 docker-machine –help 命令查看。

总结

Docker Machine 最主要有两个作用:

  • 使用 Docker Machine 方便在不同的环境中使用 Docker ,比如:Win/Mac
  • 使用 Docker Machine 方便在云环境下批量部署 Docker环境,比如:私有云,公有云批量安装Docker环境

Docker(五):Docker 三剑客之 Docker Machine相关推荐

  1. docker——三剑客之Docker Machine

    Docker Machine是Docker官方三剑客项目之一,负责使用Docker的第一步,在多种平台上快速安装Docker环境. 它支持多种平台,让用户在很短时间内搭建一套Docker主机集群. M ...

  2. docker三剑客之 Docker Machine Docker Compose Docker Swarm

    Docker 三剑客 一.docker machine 1.Docker Machine 简介 2.Docker Machine实践 二.docker-compose 1.docker-compose ...

  3. docker(6)容器的三剑客:docker machine、docker-compose、docker Swarm

    文章目录 一.docker machine 1.在已经安装docker的目标主机部署 1)server11作为管理端,创建machine 2)server12上已经安装docker 3)免密 4)创建 ...

  4. Docker(六):Docker 三剑客之 Docker Swarm

    实践中会发现,生产环境中使用单个 Docker 节点是远远不够的,搭建 Docker 集群势在必行.然而,面对 Kubernetes, Mesos 以及 Swarm 等众多容器集群系统,我们该如何选择 ...

  5. 三剑客之Docker Swarm

    目录 一.什么是Docker Swarm 二.Docker Swarm 基本结构图 三.Swarm的几个关键概念 四.Swarm的工作模式 五.Swarm的调度策略 六.Swarm Cluster模式 ...

  6. Docker三剑客之Docker Swarm

    目录 一.什么是Docker Swarm 二.Docker Swarm 基本结构图 三.Swarm的几个关键概念 四.Swarm的工作模式 五.Swarm的调度策略 六.Swarm Cluster模式 ...

  7. Docker 三剑客之Docker Swarm

    Docker Swarm 介绍 Swarm 在 Docker 1.12 版本之前属于一个独立的项目,在 Docker 1.12 版本发布之后,该项目合并到了 Docker 中,成为 Docker 的一 ...

  8. Docker系列之五:Docker 三剑客之 Docker Swarm

    title: Docker系列之五:Docker 三剑客之 Docker Swarm categories: Docker tags: - Docker timezone: Asia/Shanghai ...

  9. 五阿哥钢铁平台Docker容器云平台建设经验分享——你想知道的这里都有!

    前言 五阿哥钢铁电商平台(www.wuage.com)是由钢铁行业第一的中国五矿与互联网第一的阿里巴巴联手打造,并充分运用双方股东优势资源,即:阿里巴巴在大数据.电商运营.互联网产品技术上的巨大优势, ...

最新文章

  1. Nature:给博士研究生的四条箴言Four golden lessons,颜宁推荐
  2. 深入探讨用位掩码代替分支(7):MMX指令集速度测试
  3. C++ 继承Employee类
  4. PHp批量推送数据太慢,PHP非阻塞批量推送数据-php教程
  5. Python解决数独
  6. 生成下拉框的几种方法总结——数据来源:数据库
  7. python中函数type可以测试对象类型_python类型检测最终指南--Typing模块的使用
  8. 总奖池2.5万美元,Kaggle 新赛,单细胞分类与分割
  9. java异常处理机制--常见异常汇总
  10. vue开发中v-for在Eslint的规则检查下出现:Elements in iteration expect to have 'v-bind:key' directives...
  11. vue 中引入阿里云的云盾防水墙
  12. Markdown引用微博图床被防盗链不加载响应403完美解决
  13. Artifactory的搭建与使用简介
  14. matlab六轴直线插补代码
  15. 优质ppt模板分享,拿走不谢
  16. 为深度学习选择最好的GPU
  17. 关于C#不同位数相与或,或赋值时,隐藏位数扩展该留意的问题
  18. 怎么做好B2C电商平台的粉丝深度与精细化运营?
  19. oracle不足位数补零的实现sql语句
  20. 云创大数据承办清华大学南京校友会校友经济企业沙龙

热门文章

  1. 基于 Java NIO 实现简单的 HTTP 服务器
  2. JVM 垃圾回收算法及回收器详解
  3. JavaScript的5种调用函数的方法
  4. 如果有人问你关系数据库的工作原理,叫他看这篇文章How does a relational database work
  5. 查看自己电脑可以支持的最大内存量
  6. 嵌入式Linux下Camera编程--V4L2【转】
  7. Linux Ubuntu常用命令
  8. 绑定线程到特定CPU处理器
  9. 关于 屏幕阅读器 和 sr-only
  10. 用Redis实现微博关注关系