摘要:是官方提供的一个工具,在集群环境中它可以帮助我们在远程的机器上安装。安装新版本中和版的已经集成了,系统中需要自己手动安装。这样做是为了让能够免密登陆到其他机器来执行安装命令。而并不是简单的安装使用。
Docker Machine 是 Docker 官方提供的一个工具,在集群环境中它可以帮助我们在远程的机器上安装 Dockerr。我们还可以通过 docker-machine 命令来管理这些虚拟机和 Docker。下面是来自 Docker Machine 官方文档的一张图,很形象!
本文主要记录在安装docker machine的过程中遇到的问题,给遇到相同问题的朋友一点思路,同时方便自己后面查看。
1、安装Docker Machine新版本中Windows和Mac版的docker已经集成了Docker machine,Linux系统中需要自己手动安装。我这里使用的是Ubuntu来做Docker Host,只需要从GitHub上直接下载编译好的文件执行即可。Git上还提供了安装命令,如下图:
安装好之后通过docker-machine -v或docker-machine version 来验证是否安装成功。
如果我们需要在多台主机安装Docker时,ssh到每台主机多带带安装也不是不行,但这样很浪费时间精力。Docker Machine的出现就帮我们解决了在多台主机上安装Docker的问题。
准备工作为了让Docker Machine能够帮我们自动安装Docker到其他主机,需要做一下几点准备工作:
在Docker Machine主机生成ssh key,一一copy到需要安装 Docker的机器。这样做是为了让Docker Mechine能够免密登陆到其他机器来执行安装命令。
在目标主机上设置用户sudo时不需要输入密码。
在Docker Machine主机生成ssh key并copy到目标主机在Docker Machine主机执行ssh-keygen命令,一路回车即可。生成成功后执行ssh-copy-id命令将ssh key copy到目标主机。注意此处目标主机的用户名如何和Docker Machine主机的用户名不同,需要明确写出用户名,建议采用如下方法。
ssh-copy-id userName@targetIpAddress
在目标主机执行如下命令
sudo vim /etc/sudoers
在最后一行添加如下代码,一定要在最后一行添加,我在安装过程中遇到很多ssh的莫名其妙问题就是因为这行代码没在最后一行。至于为什么目前也没搞懂。。。
用户名 ALL=(ALL:ALL) NOPASSWD : ALL
此处的用户名需要和前面ssh-copy-id时的用户名一致。准备工作已经就绪,下面我们来为远程主机安装Docker。
3、为远程主机安装Docker在Docker Mechine主机执行如下命令
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导致安装失败,但多尝试几次也会安装成功。因此在小规模集群时安装速度不如直接安装或者利用一键脚本直接安装。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/27539.html
摘要:既然要组集群那就涉及诸如的资源调度管理等等一系列问题。目前涉及集群的三个主要的技术无外乎三种。从本文开始作者将会一一实践这几种主要的集群技术,话不多说,现在开始。完全运行于内存中,体积小,启动快。 showImg(https://segmentfault.com/img/remote/1460000015723680); 前言 相信Docker技术大家都有所了解,单个Docker能发...
摘要:参考引用会输出几行语句,例如的意思就是把上面的输出当做命令在当前下执行。最终的结果就是当前下多了几个环境变量,就是靠着这些环境变量来决定和交互的行为的。 上篇:http://www.jianshu.com/p/bde1... 已经记录到了再docker-machine学习中遇到的问题,但是大部分都是安装的问题,还有在运行过程中遇到的问题,这篇我将记录docker-machine详细得操...
摘要:远程部署一概要发布之前,你可能会遇到以下问题你需要登录主机,按照主机及操作系统特有的安装以及配置步骤安装,使其能运行容器你需要研发一套工具管理多个主机并监控其状态你在本地开发,产品部署在公有云平台,你希望能尽可能的减小两个环境的差异性的出现 Docker Machine远程部署Docker 一、docker machine概要 Docker Machine发布之前,你可能会遇到以下问题...
摘要:如果使用操作系统自带包安装,目前安装的版本是比较旧的。之前版本如果是较低版本的系统,需要先更新内核。然后重复上面的步骤即可。 Quick Start Installation Ubuntu 通过系统自带包安装 Ubuntu 14.04 版本系统中已经自带了 Docker 包,可以直接安装。 $ sudo apt-get update $ sudo apt-get install -y ...
摘要:链接地址首先,是基于开发的,所以本质上在和上是无法运行的,当然我们不可能每个人都拿作为开发机,所以官方给出了方法在和上运行。 Because the Docker daemon uses Linux-specific kernel features, you can’t run Docker natively in OS X. Instead, you must use docker-...
阅读 2786·2021-11-18 10:02
阅读 3639·2021-11-15 17:59
阅读 2279·2021-09-06 15:00
阅读 3324·2019-08-29 16:58
阅读 1036·2019-08-26 10:34
阅读 1563·2019-08-26 10:15
阅读 1268·2019-08-26 10:11
阅读 2669·2019-08-23 18:33