热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Dockermachine安装过程

DockerMachine是Docker官方提供的一个工具,在集群环境中它可以帮助我们在远程的机器上安装Dockerr。我们还可以通过docker-machine命令

Docker Machine 是 Docker 官方提供的一个工具,在集群环境中它可以帮助我们在远程的机器上安装 Dockerr。我们还可以通过 docker-machine 命令来管理这些虚拟机和 Docker。下面是来自 Docker Machine 官方文档的一张图,很形象!

安装好之后通过docker-machine -v或docker-machine version 来验证是否安装成功。
验证Docker Machine是否安装成功

2、在远程主机上安装Docker

如果我们需要在多台主机安装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时不需要输入密码

在目标主机执行如下命令

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 会用它来设置目标主机的名称。

4、Docker Machine可以直接创建带有Docker的虚拟机,具体操作方法可以参考sparkdev的这篇博客。

总结

Docker-Machine确实为我们搭建集群环境提供了很大的便利,但在我实际操作的过程中发现,使用Docker-Machine很容易遇到各种Bug导致安装失败,但多尝试几次也会安装成功。因此在小规模集群时安装速度不如直接安装或者利用一键脚本直接安装。



推荐阅读
  • 本文详细介绍了如何在 Linux 系统上安装 JDK 1.8、MySQL 和 Redis,并提供了相应的环境配置和验证步骤。 ... [详细]
  • 本文详细介绍了在 Ubuntu 系统上搭建 Hadoop 集群时遇到的 SSH 密钥认证问题及其解决方案。通过本文,读者可以了解如何在多台虚拟机之间实现无密码 SSH 登录,从而顺利启动 Hadoop 集群。 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • 本文介绍了如何在 Windows 系统上利用 Docker 构建一个包含 NGINX、PHP、MySQL、Redis 和 Elasticsearch 的集成开发环境。通过详细的步骤说明,帮助开发者快速搭建和配置这一复杂的技术栈,提升开发效率和环境一致性。 ... [详细]
  • CentOS 7环境下Jenkins的安装与前后端应用部署详解
    CentOS 7环境下Jenkins的安装与前后端应用部署详解 ... [详细]
  • 在CentOS上部署并使用FFmpeg多媒体处理工具
    最近在进行音频处理时需要用到FFmpeg,本文将详细介绍如何在CentOS系统上部署并使用这一强大的多媒体处理工具。首先,从官方网站下载FFmpeg的最新版本,然后通过Xftp工具将下载的压缩包(如ffmpeg-4.3.1.tar.xz)传输到服务器上。接下来,解压文件并按照官方文档进行编译安装。安装完成后,可以通过命令行工具验证FFmpeg是否成功安装,并开始进行多媒体文件的转换和处理。此外,文章还将介绍一些常用的FFmpeg命令和参数,帮助用户快速上手。 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 在使用SSH框架进行项目开发时,经常会遇到一些常见的问题。例如,在Spring配置文件中配置AOP事务声明后,进行单元测试时可能会出现“No Hibernate Session bound to thread”的错误。本文将详细探讨这一问题的原因,并提供有效的解决方案,帮助开发者顺利解决此类问题。 ... [详细]
  • 求助:在CentOS 5.8系统上安装PECL扩展遇到问题
    在 CentOS 5.8 系统上尝试安装 APC 扩展时遇到了问题,具体表现为 PECL 工具无法正常工作。为了确保顺利安装,需要解决 PECL 的相关依赖和配置问题。建议检查 PHP 和 PECL 的版本兼容性,并确保所有必要的库和开发工具已正确安装。此外,可以尝试手动下载 APC 扩展的源代码并进行编译安装,以绕过 PECL 工具的限制。 ... [详细]
  • 本文深入解析了 FCEUX 源码,并详细介绍了两种制作 DEB 包的方法及其技术细节。首先,DEB 包通常由两部分组成:控制信息(位于 DEBIAN 目录)和安装内容(模拟目录)。通过解压现有的 DEB 包,可以查看其内部结构,进而理解其工作原理。具体操作包括将安装内容释放到指定目录中,以便进行进一步的修改和定制。此外,文章还探讨了如何修改现有的 DEB 包,以满足特定需求,提供了实用的步骤和技巧。 ... [详细]
  • 基址获取与驱动开发:内核中提取ntoskrnl模块的基地址方法解析
    基址获取与驱动开发:内核中提取ntoskrnl模块的基地址方法解析 ... [详细]
  • Linux入门教程第七课:基础命令与操作详解
    在本课程中,我们将深入探讨 Linux 系统中的基础命令与操作,重点讲解网络配置的相关知识。首先,我们会介绍 IP 地址的概念及其在网络协议中的作用,特别是 IPv4(Internet Protocol Version 4)的具体应用和配置方法。通过实际操作和示例,帮助初学者更好地理解和掌握这些基本技能。 ... [详细]
  • 在 openSUSE Tumbleweed 系统上搭建 51 单片机开发环境并进行编程实践。首先,通过 `sudo zypper in emacs` 命令安装文本编辑器 Emacs。接着,使用 `sudo zypper in sdcc` 安装 SDCC 编译器。最后,利用 `wget` 下载 sdcflash Python 脚本,以便于单片机的烧录和调试。此外,还介绍了如何配置开发环境,确保各组件协同工作,提高开发效率。 ... [详细]
  • 在搭建Hadoop集群以处理大规模数据存储和频繁读取需求的过程中,经常会遇到各种配置难题。本文总结了作者在实际部署中遇到的典型问题,并提供了详细的解决方案,帮助读者避免常见的配置陷阱。通过这些经验分享,希望读者能够更加顺利地完成Hadoop集群的搭建和配置。 ... [详细]
author-avatar
会飞的狼
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有