hadoop +hbase +zookeeper 完全分布搭建 (版本二

本文涉及的产品
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 这里有几个主要关系: 1.经过Map、Reduce运算后产生的结果看上去是被写入到HBase了,但是其实HBase中HLog和StoreFile中的文件在进行flush to disk操作时,这两个文件存储到了HDFS的DataNode中,HDFS才是永久存储。 2.ZooKeeper跟Hadoop Core、HBase有什么关系呢?ZooKeeper都提供了哪些服务呢?主

这里有几个主要关系:

1.经过Map、Reduce运算后产生的结果看上去是被写入到HBase了,但是其实HBase中HLog和StoreFile中的文件在进行flush to disk操作时,这两个文件存储到了HDFS的DataNode中,HDFS才是永久存储。

2.ZooKeeper跟Hadoop Core、HBase有什么关系呢?ZooKeeper都提供了哪些服务呢?主要有:管理Hadoop集群中的NameNode,HBase中HBaseMaster的选举,Servers之间状态同步等。具体一点,细一点说,单只HBase中ZooKeeper实例负责的工作就有:存储HBase的Schema,实时监控HRegionServer,存储所有Region的寻址入口,当然还有最常见的功能就是保证HBase集群中只有一个Master。





2、搭建完全分布式集群

在做hadoop,hbase这方面的工作有一段时间了,经常有刚接触这些东西的身边朋友,向我询问基本环境的搭建问题,于是就想以回忆录的形式把基本配置的步骤整理出来,以便刚接触的朋友做个参考.

      HBase集群建立在hadoop集群基础之上,所以在搭建HBase集群之前需要把Hadoop集群搭建起来,并且要考虑二者的兼容性.现在就以四台机器为例,搭建一个简单的集群.

   使用的软件版本:hadoop-1.0.3,hbase-0.94.2,zookeeper-3.4.4.

   四台机器IP:10.2.11.1,10.2.11.2,10.2.11.3,10.2.11.4.


一.搭建Hadoop集群


   1. 安装JDK.在每台机器下建立相同的目录/usr/java.把下载的jdk(1.6及以上版本)复制到/usr/java目录下面,使用命令

  • tar –zxvf  jdk-7u9-linux-i586.tar.gz  
  • sudo chmod 777 jdk-1.7.0_09  




把jdk的路径加到环境变量中:                  

  • vim.tiny  /etc/profile  




  在该文件最后一行添加:

  • JAVA_HOME=/usr/java/jdk1.7.0_09  
  •             PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:PATH  
  •                CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib  




使修改的操作生效:                          

  • source   /etc/profile             




可以使用                                                

  • java  -version  




进行验证是否已配置成功.

2.在每台机器上建立相同的用户名                             

  • sudo adduser  cloud  
  • password   cloud  




输入你要设置的密码.然后在每台机器作配置:                          

  • sudo gedit  /etc/hosts  




   打开文件后加入如下内容:                    

  • 10.2.11.1 namenode  
  • 10.2.11.2 datanode1  
  • 10.2.11.3 datanode2  
  • 10.2.11.4 datanode3  




3.在/home/cloud/目录下建立一个文件夹project,命令如下:                  

  • mkdir  project    




        把hadoop-1.0.3.tar.gz,zookeeper-3.4.4.tar.gz,hbase-0.94.2.tar.gz,这些下载的软件包放在此目录下面,以待下一步操作。
4.使用命令

  • tar  –zxvf   hadoop-1.0.3.tar.gz  




进行解压文件.进入配置目录,开始配置.   

  • cd  hadoop-1.0.3/conf  




5. 使用命令 : vim.tiny   hadoop-env.sh 把java的安装路径加进去:

  • JAVA_HOME=/usr/java/jdk1.7.0_09/  




6. vim.tiny   core-site.xml ,加入如下配置:

  • <property>  
  •                <name>hadoop.tmp.dir</name>  
  •                           <value>/home/cloud/project/tmp</value>  
  • </property >  
  • < property >  
  •                  <name> fs.default.name</name>  
  •                        <value>hdfs://namenode:9000</value>  
  • </property >  




7.  vim.tiny   hdfs-site.xml,加入如下配置:

  • <property >  
  • <name>dfs.repplication</name>  
  • <value>3</value>  
  • </property >  
  • <property>  
  • <name>dfs.data.dir</name>  
  • <value>/home/cloud/project/tmp/data</value>  
  • </ property >  




8. gedit   mapred-site.xml,添加如下内容:

  • <property>  
  • <name>mapred.job.tracker</name>  
  • <value>namenode:9001</value>  
  • </property >  




9. gedit   master,加入如下配置内容:

  • namenode  




  10. gedit   slaves,加入如下配置内容:

  • datanode1  
  • datanode2  
  • datanode3   




11. 配置机器之间无密码登陆.在每台机器下建立相同目录 .ssh ,如

  • mkdir     /home/cloud/.ssh  




在namenode节点下,使用命令ssh-keygen –t rsa,然后一直回车(中间不用输入任何其他信息),直到结束,然后使用命令cd .ssh,

  • cp id_rsa.pub authorized.keys      




使用远程传输,把authorized.keys分别复制到其他机器的.ssh目录下面,命令如下:

  • scp authorized_keys  datanode1:/home/cloud/.ssh  
  • scp authorized_keys  datanode2:/home/cloud/.ssh  
  •        scp authorized_keys  datanode3:/home/cloud/.ssh         




  进入每台机器的.ssh目录下修改authorized_keys的权限,命令如下:

  • chmod 644 authorized_keys     




12.把配置好的hadoop分别拷贝到集群中其他机器上,命令如下:

  • scp –r hadoop-1.0.3  datanode1:/home/cloud/project  
  • scp –r hadoop-1.0.3  datanode2:/home/cloud/project  
  •      scp –r hadoop-1.0.3  datanode3:/home/cloud/project       




13.在namenode机器下,进入hadoop的安装目录,对文件系统进行格式化:

  • bin/hadoop namenode   –format    




14. 启动集群: bin/start-all.sh.      可以使用

  • bin/hadoop  dfsadmin  –report                  




查看文件系统的使用情况。      使用命令

  • jps  




查看节点服务启动情况,正常情况有:jobtracker、namenode、jps、secondnamenode.否则启动异常,重新检查安装步骤。

  二.安装zookeeper      

1.在namenode机器下,配置zookeeper,先解压安装包,使用命令:

  • tar -zxvf zookeeper-3.4.4.tar.gz       




2.进入zookeeper的配置目录,首先把zoo_sample.cfg重命名一下,可以重新复制一遍,使用命令:

  • cp zoo_sample.cfg zoo.cfg      




3.gedit    zoo.cfg ,添加如下内容:

  •                dataDir=/home/cloud/project/tmp/zookeeper/data  
  • server.1 = datanode1:7000:7001  
  • server.2 =datanode2:7000:7001  
  • server.3 =datanode3:7000:7001  




4.把zookeeper分别远程拷贝datanode1,datanode2,datenode3,使用如下命令:

  • scp –r zookeeper-3.4.4  datanode1:/home/cloud/project  
  • scp –r zookeeper-3.4.4  datanode2:/home/cloud/project  
  • scp –r zookeeper-3.4.4  datanode3:/home/cloud/project  




5.分别在刚才的datanode节点/home/cloud/project/tmp/zookeeper/data目录下,新建文件myid,然后使用命令

  • vim.tiny  myid  




   分别在datanode1,datanode2,datanode3的myid中写入对应的server.n中的n,即分别是1,2,3.

6.开启zookeeper服务,在三台datanode机器的zookeeper安装目录下使用命令:

  • bin/zkServer.sh start  




三.部署hbase

1.解压缩hbase的软件包,使用命令:

  • tar -zxvf hbase-0.94.2.tar.gz  




2.进入hbase的配置目录,在hbase-env.sh文件里面加入java环境变量.即:

  • JAVA_HOME=/usr/java/jdk1.7.0_09/    




加入变量:

  • export  HBASE_MANAGES_ZK=false  




3. 编辑hbase-site.xml ,添加配置文件:

  • <property>  
  • <name>hbase.rootdir</name>  
  • <value>hdfs://namenode:9000/hbase</value>  
  • </property>  
  • <property>  
  • <name>hbase.cluster.distributed</name>  
  • <value>true</value>  
  • </property>  
  • <property>  
  • <name>hbase.zookeeper.quorum</name>  
  • <value>datanode1,datanode2,datanode3</value>  
  • </property>  
  • <property>  
  • <name>hbase.zookeeper.property.dataDir</name>  
  • <value>/home/cloud/project/tmp/zookeeper/data</value>  
  • </property>  




4. 编辑配置目录下面的文件regionservers. 命令:

  • vim.tiny    regionservers    




加入如下内容:

  • datanode1  
  • datanode2  
  • datandoe3  




5. 把Hbase复制到其他机器,命令如下:

  • scp -r hbase-0.94.2   datanode1:/home/cloud/project  
  • scp -r hbase-0.94.2   datanode2:/home/cloud/project  
  • scp -r hbase-0.94.2   datanode3:/home/cloud/project  




6. 开启hbase服务。命令如下:

  • bin/start-hbase.sh     




可以使用bin/hbaseshell 进入hbase自带的shell环境,然后使用命令version等,进行查看hbase信息及建立表等操作。   

相关实践学习
lindorm多模间数据无缝流转
展现了Lindorm多模融合能力——用kafka API写入,无缝流转在各引擎内进行数据存储和计算的实验。
云数据库HBase版使用教程
&nbsp; 相关的阿里云产品:云数据库 HBase 版 面向大数据领域的一站式NoSQL服务,100%兼容开源HBase并深度扩展,支持海量数据下的实时存储、高并发吞吐、轻SQL分析、全文检索、时序时空查询等能力,是风控、推荐、广告、物联网、车联网、Feeds流、数据大屏等场景首选数据库,是为淘宝、支付宝、菜鸟等众多阿里核心业务提供关键支撑的数据库。 了解产品详情:&nbsp;https://cn.aliyun.com/product/hbase &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3月前
|
分布式计算 Hadoop Shell
Hadoop-35 HBase 集群配置和启动 3节点云服务器 集群效果测试 Shell测试
Hadoop-35 HBase 集群配置和启动 3节点云服务器 集群效果测试 Shell测试
98 4
|
3月前
|
SQL 分布式计算 Hadoop
Hadoop-37 HBase集群 JavaAPI 操作3台云服务器 POM 实现增删改查调用操作 列族信息 扫描全表
Hadoop-37 HBase集群 JavaAPI 操作3台云服务器 POM 实现增删改查调用操作 列族信息 扫描全表
46 3
|
3月前
|
分布式计算 Hadoop Shell
Hadoop-36 HBase 3节点云服务器集群 HBase Shell 增删改查 全程多图详细 列族 row key value filter
Hadoop-36 HBase 3节点云服务器集群 HBase Shell 增删改查 全程多图详细 列族 row key value filter
70 3
|
3月前
|
SQL 分布式计算 Hadoop
Hadoop-34 HBase 安装部署 单节点配置 hbase-env hbase-site 超详细图文 附带配置文件
Hadoop-34 HBase 安装部署 单节点配置 hbase-env hbase-site 超详细图文 附带配置文件
121 2
|
3月前
|
分布式计算 Kubernetes Hadoop
大数据-82 Spark 集群模式启动、集群架构、集群管理器 Spark的HelloWorld + Hadoop + HDFS
大数据-82 Spark 集群模式启动、集群架构、集群管理器 Spark的HelloWorld + Hadoop + HDFS
207 6
|
3月前
|
分布式计算 资源调度 Hadoop
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
96 2
|
24天前
|
存储 分布式计算 大数据
Flume+Hadoop:打造你的大数据处理流水线
本文介绍了如何使用Apache Flume采集日志数据并上传至Hadoop分布式文件系统(HDFS)。Flume是一个高可用、可靠的分布式系统,适用于大规模日志数据的采集和传输。文章详细描述了Flume的安装、配置及启动过程,并通过具体示例展示了如何将本地日志数据实时传输到HDFS中。同时,还提供了验证步骤,确保数据成功上传。最后,补充说明了使用文件模式作为channel以避免数据丢失的方法。
60 4
|
2月前
|
存储 分布式计算 Hadoop
数据湖技术:Hadoop与Spark在大数据处理中的协同作用
【10月更文挑战第27天】在大数据时代,数据湖技术凭借其灵活性和成本效益成为企业存储和分析大规模异构数据的首选。Hadoop和Spark作为数据湖技术的核心组件,通过HDFS存储数据和Spark进行高效计算,实现了数据处理的优化。本文探讨了Hadoop与Spark的最佳实践,包括数据存储、处理、安全和可视化等方面,展示了它们在实际应用中的协同效应。
145 2
|
2月前
|
存储 分布式计算 Hadoop
数据湖技术:Hadoop与Spark在大数据处理中的协同作用
【10月更文挑战第26天】本文详细探讨了Hadoop与Spark在大数据处理中的协同作用,通过具体案例展示了两者的最佳实践。Hadoop的HDFS和MapReduce负责数据存储和预处理,确保高可靠性和容错性;Spark则凭借其高性能和丰富的API,进行深度分析和机器学习,实现高效的批处理和实时处理。
122 1
|
3月前
|
分布式计算 Hadoop 大数据
大数据体系知识学习(一):PySpark和Hadoop环境的搭建与测试
这篇文章是关于大数据体系知识学习的,主要介绍了Apache Spark的基本概念、特点、组件,以及如何安装配置Java、PySpark和Hadoop环境。文章还提供了详细的安装步骤和测试代码,帮助读者搭建和测试大数据环境。
98 1