Docker Machine 是 Docker 官方提供的一个工具,在集群环境中它能够帮助咱们在远程的机器上安装 Dockerr。咱们还能够经过 docker-machine 命令来管理这些虚拟机和 Docker。下面是来自 Docker Machine 官方文档的一张图,很形象!html
本文主要记录在安装docker machine的过程当中遇到的问题,给遇到相同问题的朋友一点思路,同时方便本身后面查看。git
新版本中Windows和Mac版的docker已经集成了Docker machine,Linux系统中须要本身手动安装。我这里使用的是Ubuntu来作Docker Host,只须要从GitHub上直接下载编译好的文件执行便可。Git上还提供了安装命令,以下图:
安装好以后经过docker-machine -v或docker-machine version 来验证是否安装成功。github
若是咱们须要在多台主机安装Docker时,ssh到每台主机单独安装也不是不行,但这样很浪费时间精力。Docker Machine的出现就帮咱们解决了在多台主机上安装Docker的问题。docker
为了让Docker Machine可以帮咱们自动安装Docker到其余主机,须要作一下几点准备工做:vim
在Docker Machine主机执行ssh-keygen命令,一路回车便可。生成成功后执行ssh-copy-id命令将ssh key copy到目标主机。注意此处目标主机的用户名如何和Docker Machine主机的用户名不一样,须要明确写出用户名,建议采用以下方法。ssh-copy-id userName@targetIpAddress
ssh
在目标主机执行以下命令工具
sudo vim /etc/sudoers
在最后一行添加以下代码,必定要在最后一行添加,我在安装过程当中遇到不少ssh的莫名其妙问题就是由于这行代码没在最后一行。至于为何目前也没搞懂。。。spa
用户名 ALL=(ALL:ALL) NOPASSWD : ALL
此处的用户名须要和前面ssh-copy-id时的用户名一致。准备工做已经就绪,下面咱们来为远程主机安装Docker。3d
在Docker Mechine主机执行以下命令code
docker-machine create -d generic \ --generic-ip-address=xxx.xxx.xxx.xxx \ --generic-ssh-user=xxx \ hostName
须要注意的是,create命令原本是要建立带有docker的虚拟机。而并非简单的安装Docker使用。搞清楚这一点很重要,我本身在最开始的时候就由于没搞清楚这个致使不少东西都没法理解。
但如今咱们已经建立好了虚拟机,只须要安装Docker便可。上述命令中 -d 是 --driver 的简写形式,主要用来指定使用什么驱动程序来建立目标主机。Docker Machine官方支持不少版本的driver,能够根据须要自行在官网查看使用。本例中使用 generic 就能够了。接下来以 --generic-ip-address用来设置须要安装Docker的主机IP,--generic-ssh-user用来设置链接目标主机时的ssh用户,此处的user须要与前面ssh-copy-id时的用户名一致。最后一个参数 hostName是虚拟机的名称,Docker Machine 会用它来设置目标主机的名称。
Docker-Machine确实为咱们搭建集群环境提供了很大的便利,但在我实际操做的过程当中发现,使用Docker-Machine很容易遇到各类Bug致使安装失败,但多尝试几回也会安装成功。所以在小规模集群时安装速度不如直接安装或者利用一键脚本直接安装。