在Docker上建立多节点的Hadoop集群

大数据 Hadoop
在上篇文章中你已经看到了在你的devbox创建一个单点Hadoop 集群是多么简单。现在我们提高门槛,在Docker上创建一个多点hadoop集群。

上篇文章中你已经看到了在你的devbox创建一个单点Hadoop 集群是多么简单。

现在我们提高门槛,在Docker上创建一个多点hadoop集群。在开始前,确保你有***的Ambari镜像:

  1. docker pull sequenceiq/ambari:latest 

一行命令

一旦你得到了***的镜像,你就可以启动Docker容器。我们已经创建了几个shell 函数来帮你输入Docker命令,从而避免输入像docker run [options] image [command]这样冗长的命令。

有了这些功能,创建3个节点的hadoop簇,只需要下面一行代码搞定:

  1. curl -Lo .amb j.mp/docker-ambari && . .amb && amb-deploy-cluster 

默认参数值都是可以根据需要更改的,像是blueprint,簇大小,等等 … 在shellj.mp/docker-ambari功能函数的头文件有参数列表.

它是按照下面步骤来实现的:

  •  在Docker (后台运行) 容器的守护进程上运行sambari-server start (记得还有 anambari-agent start)

  • 运行sn-1 守护进程容器并用ambari-agent start连接到服务器

  • 运行AmbariShell 以及其终端控制台 (监控子进程)

    • AmbariShell 会把内置的多节点blueprint发送至 /api/v1/blueprintsREST API

    • AmbariShell 依照blueprint的设置自动分配宿主信息

    • 通过发送至/api/v1/clustersREST API的内容创建簇

自定义

如果你有自己定义好的脚本,可以放在 gist然后运行 AmbariShell. 先启动 AmbariShell:

  1. amb-start-cluster 2  
  2. amb-shell 

AmbariShell启动的前提:

  • Ambari REST API 将帮助你建立多个hadoop端.

  1. host list  
  2. blueprint add --url https://gist.githubusercontent.com/lalyos/xxx/raw/custum-blueprint.json  
  3. cluster build --blueprint custom-blueprint  
  4. cluster assign --hostGroup host_group_1 --host amb0.mycorp.kom  
  5. cluster assign --hostGroup host_group_2 --host amb1.mycorp.kom  
  6. cluster assign --hostGroup host_group_2 --host amb1.mycorp.kom  
  7. cluster create 

AmbariShell 的 hint命令能帮助开发人员实现自动补全等功能.

自动补全包括:

  • 补全命令行 (例如,没有这个帮助下 cluster命令是不可用的)

  • 添加需要的参数

  • 添加备选参数: --后加上<TAB>

  • 添加变参,像是参数名,宿主名等等 …

总结

基本上我们开始使用Docker的时候就已经使用多端的hadoop功能了 – 笔记本上运行3到4簇面临的极限问题比 Sandbox VM少得多.

我们使用了docker的模式简化了hadoop的使用模式 – 可以在 LinkedIn找到我们关于Cloudbreak的***进展 – 开源云端的Hadoop as a Service API应用并构建在 docker上.

希望本文能帮你简化你的开发流程 – 如有什么关于docker上使用hadoop问题,欢迎沟通。

英文原文:Multi-node Hadoop cluster on Docker

译文出自:http://www.oschina.net/translate/multinode-hadoop-cluster-on-docker

责任编辑:林师授 来源: 开源中国社区 编译
相关推荐

2015-05-27 10:29:41

DockerHadoopHadoop集群

2023-09-11 09:35:20

Docker程序

2019-09-27 08:52:12

RHELCentOSElastic sta

2019-09-03 16:18:03

Vagran虚拟机集群

2010-04-01 10:13:22

CentOS系统

2016-01-07 09:36:20

Docker容器

2013-12-04 13:32:30

2012-05-21 09:42:12

Hadoop

2020-04-06 13:52:45

数据仓库大数据平台Hadoop

2019-07-26 09:20:21

ClusterShel命令Linux

2018-10-09 14:31:32

SparkCI灰度

2010-08-12 15:41:12

MySQL集群

2023-11-02 09:00:00

Kubernetes集群

2016-07-28 12:34:22

天蝎OpenStack中国移动

2023-11-09 16:13:53

2020-07-20 18:30:44

Fedora 32DockerLinux

2017-02-28 09:48:30

2023-05-04 18:45:11

2011-01-14 14:00:19

GanetiLinux集群虚拟化

2009-06-12 17:45:16

JMS集群JBoss集群
点赞
收藏

51CTO技术栈公众号