CDH5搭建
系统要求
系统:CentOS 6.5
Cloudera:CM5.2.0 + CDH 5.2.0
内存:主节点4G内存以上,其他节点需要2G以上内存
Hadoop版本选择
目前Hadoop比较流行的主要有2个版本,Apache和Cloudera版本。
Apache Hadoop:维护人员比较多,更新频率比较快,但是稳定性比较差。
Cloudera Hadoop(CDH):CDH:Cloudera公司的发行版本,基于ApacheHadoop的二次开发,优化了组件兼容和交互接口、简化安装配置、增加Cloudera兼容特性。
准备工作
以下步骤要在所有节点上执行
-
修改hostname
1vi /etc/sysconfig/network 2
- 关闭SELinux
查看SELinux状态
1getenforce 2
若SELinux没有关闭,按照下述方式关闭
1vi /etc/selinux/config 2
修改SELinux=disabled。重启生效,可以等后面都设置完了重启主机
1# This file controls the state of SELinux on the system. 2# SELINUX= can take one of these three values: 3# enforcing - SELinux security policy is enforced. 4# permissive - SELinux prints warnings instead of enforcing. 5# disabled - SELinux is fully disabled. 6SELINUX=disabled 7# SELINUXTYPE= type of policy in use. Possible values are: 8# targeted - Only targeted network daemons are protected. 9# strict - Full SELinux protection. 10SELINUXTYPE=targeted 11
-
关闭防火墙
1sudo service iptables stop 2sudo chkconfig iptables off 3sudo chkconfig iptables --list 4
-
网络配置
1vim /etc/sysconfig/network-scripts/ifcfg-eth0 2
设置静态ip,以及指定ip地址
1DEVICE="eth0" 2BOOTPROTO="static" 3IPADDR=192.168.1.110 4NM_CONTROLLED="yes" 5ONBOOT="yes" 6TYPE="Ethernet" 7DNS1=8.8.8.8 8DNS2=8.8.4.4 9GATEWAY=192.168.1.1 10
- 修改hosts文件
把所有要添加到集群中的主机都要加入hosts中,格式如下:
1127.0.0.1 localhost 2 3# CDH Cluster 4192.168.1.110 master 5192.168.1.111 slave1 6192.168.1.112 slave2 7
以上步骤执行完毕后,重启主机
1reboot 2
重启后再次检查下以上几点,确保环境配置正确。
提前下载(本教程中,CM和CDH版本均为5.2.0)
- 下载cloudera-manager.repo
修改baseurl中cm版本为实际版本,本例中改成5.2.0
1 [cloudera-manager] 2 # Packages for Cloudera Manager, Version 5, on RedHat or CentOS 6 x86_64 3 name=Cloudera Manager 4 baseurl=https://archive.cloudera.com/cm5/redhat/6/x86_64/cm/5.2.0/ 5 gpgkey =https://archive.cloudera.com/cm5/redhat/6/x86_64/cm/RPM-GPG-KEY-cloudera 6 gpgcheck = 1 7
- 下载CM installer
- 下载CM rpms,目录下全部下载出来
- 下载CDH Parcel文件,只需要下载图中所示的3个文件
CDH文件下载
这里注意下,将.sha1文件后缀更改为.sha,同时把内容只保留hash码部分。(5.2.0版本sha文件内容本身就只包含hash码,不需要修改,其他版本请自行查看!)
Cloudera Manager安装
以下步骤要在所有节点上执行:
- 将cloudera-manager.repo文件拷贝到所有节点的/etc/yum.repos.d/文件夹下
- 验证repo文件是否起效
1yum list|grep cloudera 2
1 如果列出的不是你安装的版本,执行下面命令重试 2
1yum clean all 2yum list | grep cloudera 3
- 将之前下载的rpms文件拷贝到所有节点下(任意目录)
切换到rpms目录下,执行
1yum -y install *.rpm 2
- 将之前下载的Parcel那3个文件拷贝到/opt/cloudera/parcel-repo目录下(如果没有该目录,请自行创建)
至此,/opt/cloudera/parcel-repo下面有三个文件: CDH-5.2.0-1.cdh5.2.0.p0.36-el6.parcel
mainfest.json
CDH-5.2.0-1.cdh5.2.0.p0.36-el6.parcel.sha
以下步骤请只在主节点上执行:
- 将下载好的bin文件拷贝到主节点任意目录下
- 进入该目录,给bin文件赋予可执行权限
1sudo chmod +x ./cloudera-manager-installer.bin 2
- 安装CM
1./cloudera-manager-installer.bin 2
1 接下来全部next和yes就行了,因为所需要的rpm包已经提前下载下来了,这个过程会进行的非常快。 2
CM安装成功
CDH集群安装
CM Web管理界面
如果打不开改网页,请耐心等待会。这个服务启动是需要一定时间的。
- 选择部署的版本,这里我们选择免费版的就可以了。
CM-选择版本
- 点击继续
CM-介绍
- 选择添加的主机。输入主机ip或者主机名,点击搜索。
CM-选择主机
这里如果选择一系列主机可以输入如下的内容:
1192.168.1.[101-105] 2slave[1-3].com.cn 3
勾选要添加的主机,继续下一步操作。
- 选择存储库
这里我们采用Parcel离线安装的方式,安装简便、完全离线而且更便于集群的管理。
CM-选择存储库
选择我们之前上传到服务器的CDH5.2.0版本,其他全选无,下一步。
- JDK安装选项
这里之前已经安装过了,所以不需要勾选,直接继续。
CM-JDK安装
- 提供SSH登陆凭据
由于CDH会自动管理所有主机间的SSH通讯,所以我们之前并没有手动配置各个节点间的SSH免密登录。在这里统一设置就行了,设置好密码点继续。
CM-SSH管理
- 集群安装
因为这里所需要的软件包我们之前都已经安装过了,这一步会很快结束。
CM-集群安装
安装完成
- 安装Parcel到所有主机上
因为Parcel文件已经提前下载好了,第一个进度条会直接显示已下载,然后开始分配。这个过程实际上就是将Parcel内的软件解压缩安装到各个主机上的过程。耐心等待,时间会比较长,我安装2台主机大概是需要20分钟时间。
CM-安装Parcel
安装完毕后点继续
Parcel安装完毕
- 主机检查
检查就可以了,建议不要跳过。检查结果如下:
主机检查
下面这2个都是误报,不需要理会。
主机检查2
- 安装服务
CDH5提供了你可能需要的各种服务,需要什么启动什么就行了。这里我选择了自定义,添加HBase,HDFS,MapReduce和ZooKeeper,这里大家按照自己的需求选。
CM-添加服务
- 角色分配
分配各个节点的角色
CM-角色分配
- 数据库设置
CDH默认内嵌了一个数据库,如果你需要MySQL或者Oracle请选择使用自定义数据库,点击测试连接,成功后点继续。
CM-数据库设置
- 审核更改
这里全部默认就可以了,直接继续。
CM-审核更改
- 安装完成,初始化
到这里集群已经安装部署完成了,CDH会自动对你选择的服务进行初始化设置,你也可以稍后自行开启。
CM-初始化
初始化完成后,将进入主页面
CM-主页
因为我们只安装了2台主机,而HDFS和ZooKeeper建议至少3个节点,所以页面上有一些警告,这些都不影响。到此,CDH集群部署完成。
作者:dzgdp888
链接:http://www.jianshu.com/p/57179e03795f