简介

有一段时间,没写博客了,因为公司开发分布式调用链追踪系统,用到hbase,在这里记录一下搭建过程

1、集群如下:

ip 主机名 角色
192.168.6.130 node1.jacky.com maser
192.168.6.131 node2.jacky.com slave
192.168.6.132 node3.jacky.com slave

2、文件如下:

  1. [root@node1 software]# ll
  2. 总用量
  3. -rw-r--r--. root root 9 : hadoop-2.7..tar.gz
  4. -rw-r--r--. root root 9 : hbase-1.2.-bin.tar.gz
  5. -rwxr-xr-x. root root 9 : jdk-8u11-linux-x64.rpm
  6. -rw-r--r--. root root 10 zookeeper-3.4..tar.gz

说明:安装hbase之前,需要安装hadoop环境(hbase用到hadoop的hdfs),需要zookeeper环境,需要jdk环境

3、安装hadoop、centos7.0环境配置

3.1、修改3台机器的hosts文件,配置ip和主机名映射

  1. [root@node1 jacky]# vim /etc/hosts

在文件后面添加内容为:

  1. 192.168.6.130 node1.jacky.com
  2. 192.168.6.131 node2.jacky.com
  3. 192.168.6.132 node3.jacky.com

3.2、修改3台机器hostname文件

在192.168.6.130机器中修改,修改hostname为

  1. [root@node1 jacky]# cat /etc/hostname
  2. node1.jacky.com

很显然另外两台技术设置的主机名分别为node2.jacky.com和node3.jacky.com

3.3、配置192.168.6.130可以免密码登录192.168.6.131和192.168.6.132

步骤:

  • 生成公钥和私钥
  • 修改公钥名称为authorized_keys
  1. [root@node1 ~]# ssh-keygen
  2. Generating public/private rsa key pair.
  3. Enter file in which to save the key (/root/.ssh/id_rsa):
  4. Enter passphrase (empty for no passphrase):
  5. Enter same passphrase again:
  6. Your identification has been saved in /root/.ssh/id_rsa.
  7. Your public key has been saved in /root/.ssh/id_rsa.pub.
  8. The key fingerprint is:
  9. SHA256:pvR6iWfppGPSFZlAqP35/6DEtGTvaMY64otThWoBTuk root@localhost.localdomain
  10. The key's randomart image is:
  11. +---[RSA ]----+
  12. | . o. |
  13. |.o . . |
  14. |+. o . . o |
  15. | Eo o . + |
  16. | o o..S. |
  17. | o ..oO.o |
  18. | . . ..=*oo |
  19. | ..o *=@+ . |
  20. | .oo=+@+.o.. |
  21. +----[SHA256]-----+
  22. [root@node1 .ssh]# cp id_rsa.pub authorized_keys
    [root@node1 .ssh]# chmod 777 authorized_keys #修改文件权限

说明:

authorized_keys:存放远程免密登录的公钥,主要通过这个文件记录多台机器的公钥 
id_rsa : 生成的私钥文件 
id_rsa.pub : 生成的公钥文件 
know_hosts : 已知的主机公钥清单

  1. [root@node1 .ssh]# ssh-copy-id -i root@node1.jacky.com 到自己
  1. [root@node1 .ssh]# ssh-copy-id -i root@node2.jacky.com
  1. [root@node1 .ssh]# ssh-copy-id -i root@node3.jacky.com

3.4、配置hadoop的环境变量

[root@node1 software]# vim /etc/profile

  1. # hadoop
  2. export HADOOP_HOME=/usr/local/hadoop-2.7.
  3. export HADOOP_MAPRED_HOME=$HADOOP_HOME
  4. export HADOOP_COMMON_HOME=$HADOOP_HOME
  5. export HADOOP_HDFS_HOME=$HADOOP_HOME
  6. export YARN_HOME=$HADOOP_HOME
  7. export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native
  8. export PATH=$PATH:$HADOOP_HOME/sbin:$HADOOP_HOME/bin
  9. export HADOOP_INSTALL=$HADOOP_HOME

输入 source /etc/profile 使配置文件生效。

  1. [root@node1 software]# source /etc/profile

4、hadoop配置

4.1、上传hadoop文件

  1. [root@node1 software]# ll
  2. 总用量
  3. -rw-r--r--. root root 9 : hadoop-2.7..tar.gz
  4. -rw-r--r--. root root 9 : hbase-1.2.-bin.tar.gz
  5. -rwxr-xr-x. root root 9 : jdk-8u11-linux-x64.rpm
  6. -rw-r--r--. root root 10 zookeeper-3.4..tar.gz
  7. [root@node1 software]# pwd
  8. /usr/software
  9. [root@node1 software]#

说明:我把hadoop-2.7.3.tar.gz上传到/usr/software

4.2、配置hadoop-env.sh文件

  1. # The java implementation to use.
  2. export JAVA_HOME=/usr/java/jdk1..0_11

4.3、配置yarn-env.sh文件

  1. export JAVA_HOME=/usr/java/jdk1..0_11

4.4、修改slaves文件,指定master的小弟,在master机器上,sbin目录下只执行start-all.sh,能够启动所有slave的DataNode和NodeManager

  1. [root@node1 hadoop]# cat slaves
  2. node2.jacky.com
  3. node3.jacky.com

4.5、修改hadoop核心配置文件core-site.xml

  1. <configuration>
  2. <!--配置hadoop使用的文件系统,配置hadoop内置的文件系统-->
  3. <property>
  4. <name>fs.defaultFS</name>
  5. <value>hdfs://node1.jacky.com:9000</value>
  6. </property>
  7. <!--配置hadoop数据目录-->
  8. <property>
  9. <name>hadoop.tmp.dir</name>
  10. <value>/usr/local/hadoop-2.7./tmp</value>
  11. </property>
  12. </configuration>

说明:目录/usr/local/hadoop-2.7.3/tmp,是自己新建的

4.6、修改hdfs-site.xml文件

  1. <configuration>
  2. <property>
  3. <name>dfs.namenode.secondary.http-address</name>
  4. <value>node1.jacky.com:</value>
  5. </property>
  6. <property>
  7. <name>dfs.replication</name>
  8. <value></value>
  9. </property>
  10. <property>
  11. <name>dfs.name.dir</name>
  12. <value>/usr/local/hadoop-2.7./hadoop/name</value>
  13. </property>
  14. <property>
  15. <name>dfs.data.dir</name>
  16. <value>/usr/local/hadoop-2.7./hadoop/data</value>
  17. </property>
  18. <property>
  19. <name>dfs.webhdfs.enabled</name>
  20. <value>true</value>
  21. </property>
  22. </configuration>

4.7、修改mapred-site.xml文件

  1. <configuration>
  2. <!--mapreduce配置在yarn集群上跑-->
  3. <property>
  4.         <name>mapreduce.framework.name</name>
  5. <value>yarn</value>
  6. </property>
  7. <property>
  8. <name>mapreduce.jobhistory.address</name>
  9. <value>node1.jacky.com:</value>
  10. </property>
  11. <property>
  12. <name>mapreduce.jobhistory.webapp.address</name>
  13. <value>node1.jacky.com:</value>
  14. </property>
  15. </configuration>

4.8、修改yarn-site.xml文件

  1. <configuration>
  2. <property>
  3. <name>yarn.nodemanager.aux-services</name>
  4. <value>mapreduce_shuffle</value>
  5. </property>
  6. <property>
  7. <name>yarn.nodemanager.aux-services.mapreduce.shuffle.class</name>
  8. <value>org.apache.hadoop.mapred.ShuffleHandler</value>
  9. </property>
  10. <!--配置yarn的master-->
  11. <property>
  12. <name>yarn.resourcemanager.address</name>
  13. <value>node1.jacky.com:</value>
  14. </property>
  15. <property>
  16. <name>yarn.resourcemanager.scheduler.address</name>
  17. <value>node1.jacky.com:</value>
  18. </property>
  19. <property>
  20. <name>yarn.resourcemanager.resource-tracker.address</name>
  21. <value>node1.jacky.com:</value>
  22. </property>
  23. <property>
  24. <name>yarn.resourcemanager.admin.address</name>
  25. <value>node1.jacky.com:</value>
  26. </property>
  27. <property>
  28. <name>yarn.resourcemanager.webapp.address</name>
  29. <value>node1.jacky.com:</value>
  30. </property>
  31. </configuration>

4.9、然后把在master的配置拷贝到node2.jacky.com和node3.jacky.com节点上

  1. [root@node1 hadoop-2.7.3]# scp -r hadoop-2.7. root@node2.jacky.com:/usr/local/
  2. [root@node1 hadoop-2.7.3]# scp -r hadoop-2.7. root@node3.jacky.com:/usr/local/

5、启动hadoop

5.1、格式化hadoop

  1. [root@node1 hadoop-2.7.]# hdfs namenode -format

5.2、启动hadoop

  1. [root@node1 sbin]# start-all.sh

5.3、用jps命令查看三台机器上hadoop有没起来

192.168.6.130

  1. [root@node1 sbin]# jps
  2. QuorumPeerMain
  3. NameNode
  4. ResourceManager
  5. Jps
  6. SecondaryNameNode

192.168.6.131

  1. [root@node2 jacky]# jps
  2. Jps
  3. DataNode
  4. QuorumPeerMain
  5. NodeManager

192.168.6.132

  1. [root@node2 jacky]# jps
  2. Jps
  3. DataNode
  4. QuorumPeerMain
  5. NodeManager

5.4、界面查看验证

http://192.168.6.130:8088/cluster/nodes

查看dataNode是否启动

http://192.168.6.130:50070/

好了,到这里,hadoop-2.7.3完全分布式集群搭建成功了,接下来我们将进入hbase搭建

6、hbase完全分布式集群搭建

6.1、上传到文件到/usr/software目录下,解压到/usr/local目录下

  1. [root@node2 software]# ll
  2. 总用量
  3. -rw-r--r--. root root 9 : hadoop-2.7..tar.gz
  4. -rw-r--r--. root root 9 : hbase-1.2.-bin.tar.gz
  5. -rw-r--r--. root root 10 zookeeper-3.4..tar.gz
  6. [root@node2 software]# pwd
  7. /usr/software
    [root@node2 software]# tar -xvzf hbase-1.2.5-bin.tar.gz -C /usr/local/

6.2、配置hbase环境变量vim /etc/profile

  1. #hbase
    export HBASE_HOME=/usr/local/hbase-1.2.
  2. export PATH=$HBASE_HOME/bin:$PATH

执行 source /etc/profile,让配置生效

6.3、创建目录tmp

  1. [root@node2 hbase-1.2.]# /usr/local/hbase-1.2./tmp

6.4、配置hbase-env.sh

  1. export JAVA_HOME=/usr/java/jdk1..0_11
  2.  
  3. # Extra Java CLASSPATH elements. Optional.
  4. export HBASE_CLASSPATH=/usr/local/hadoop-2.7./etc/hadoop

# Tell HBase whether it should manage it's own instance of Zookeeper or not.
export HBASE_MANAGES_ZK=false 默认是true

6.5、配置hbase-site.xml

  1. <configuration>
  2. <property>
  3. <name>hbase.rootdir</name>
  4. <value>hdfs://node1.jacky.com:9000/hbase</value>
  5. </property>
  6. <property>
  7. <name>hbase.master</name>
  8. <value>node1.jacky.com</value>
  9. </property>
  10. <property>
  11. <name>hbase.cluster.distributed</name>
  12. <value>true</value>
  13. </property>
  14. <property>
  15. <name>hbase.tmp.dir</name>
  16. <value>/usr/local/hbase-1.2./tmp</value>
  17. </property>
  18. <property>
  19. <name>hbase.zookeeper.property.clientPort</name>
  20. <value></value>
  21. </property>
  22. <property>
  23. <name>hbase.zookeeper.quorum</name>
  24. <value>node1.jacky.com,node2.jacky.com,node3.jacky.com</value>
  25. </property>
  26. <property>
  27. <name>hbase.zoopkeeper.property.dataDir</name>
  28. <value>/usr/local/zookeeper-3.4./data</value>
  29. </property>
  30. <property>
  31. <name>zookeeper.session.timeout</name>
  32. <value></value>
  33. </property>
  34. <property>
  35. <name>dfs.support.append</name>
  36. <value>true</value>
  37. </property>
  38. </configuration>

6.6、配置regionservers,其实就是配置master的小弟

  1. node2.jacky.com
  2. node3.jacky.com

6.7、用scp 命令把配置好的hbase程序分发到各个机器上

  1. scp hbase-1.2. root@node2.jacky.com:/usr/local
  2. scp hbase-1.2. root@node3.jacky.com:/usr/local

7、启动hbase,只需要在master机器上执行

  1. [root@node1 bin]# ./start-hbase.sh
  2. node3.jacky.com: starting zookeeper, logging to /usr/local/hbase-1.2./bin/../logs/hbase-root-zookeeper-node3.jacky.com.out
  3. node2.jacky.com: starting zookeeper, logging to /usr/local/hbase-1.2./bin/../logs/hbase-root-zookeeper-node2.jacky.com.out
  4. node1.jacky.com: starting zookeeper, logging to /usr/local/hbase-1.2./bin/../logs/hbase-root-zookeeper-node1.jacky.com.out
  5. starting master, logging to /usr/local/hbase-1.2./logs/hbase-jacky-master-node1.jacky.com.out
  6. node2.jacky.com: starting regionserver, logging to /usr/local/hbase-1.2./bin/../logs/hbase-root-regionserver-node2.jacky.com.out
  7. node3.jacky.com: starting regionserver, logging to /usr/local/hbase-1.2./bin/../logs/hbase-root-regionserver-node3.jacky.com.out
  8. node2.jacky.com: Java HotSpot(TM) -Bit Server VM warning: ignoring option PermSize=128m; support was removed in 8.0
  9. node2.jacky.com: Java HotSpot(TM) -Bit Server VM warning: ignoring option MaxPermSize=128m; support was removed in 8.0
  10. [root@node1 bin]#

7.1、通过jps查看hbase进程

192.168.6.130

  1. [root@node1 bin]# jps
  2. QuorumPeerMain
  3. HMaster
  4. NameNode
  5. ResourceManager
  6. SecondaryNameNode
  7. Jps

192.168.131

  1. [root@node2 local]# jps
  2. DataNode
  3. QuorumPeerMain
  4. HRegionServer
  5. NodeManager
  6. Jps

192.168.6.132

  1. [root@node2 local]# jps
  2. DataNode
  3. QuorumPeerMain
  4. HRegionServer
  5. NodeManager
  6. Jps

7.2、通过打开页面验证

到这里hbase完全分布式集群就搭建完成了

欢迎关注

搭建hbase1.2.5完全分布式集群的更多相关文章

  1. 基于hadoop2.6.0搭建5个节点的分布式集群

    1.前言 我们使用hadoop2.6.0版本配置Hadoop集群,同时配置NameNode+HA.ResourceManager+HA,并使用zookeeper来管理Hadoop集群 2.规划 1.主 ...

  2. 摘要: CentOS 6.5搭建Redis3.2.8伪分布式集群

    from https://my.oschina.net/ososchina/blog/856678     摘要: CentOS 6.5搭建Redis3.2.8伪分布式集群 前言 最近在服务器上搭建了 ...

  3. 搭建Hadoop2.7.1的分布式集群

    Hadoop 2.7.1 (2015-7-6更新),hadoop的环境配置不是特别的复杂,但是确实有很多细节需要注意,不然会造成许多配置错误的情况.尽量保证一次配置正确防止反复修改. 网上教程有很多关 ...

  4. Hadoop(二)CentOS7.5搭建Hadoop2.7.6完全分布式集群

    一 完全分布式集群(单点) Hadoop官方地址:http://hadoop.apache.org/ 1  准备3台客户机 1.1防火墙,静态IP,主机名 关闭防火墙,设置静态IP,主机名此处略,参考 ...

  5. # 从零開始搭建Hadoop2.7.1的分布式集群

    Hadoop 2.7.1 (2015-7-6更新),Hadoop的环境配置不是特别的复杂,可是确实有非常多细节须要注意.不然会造成很多配置错误的情况.尽量保证一次配置正确防止重复改动. 网上教程有非常 ...

  6. CentOS7.5搭建Hadoop2.7.6完全分布式集群

    一 完全分布式集群搭建 Hadoop官方地址:http://hadoop.apache.org/ 1  准备3台客户机 1.2 关闭防火墙,设置静态IP,主机名 关闭防火墙,设置静态IP,主机名此处略 ...

  7. Nginx之搭建反向代理实现tomcat分布式集群

    参考博文: Nginx反向代理实现Tomcat分布式集群 1. jdk 安装 jdk 下载网址: http://www.oracle.com/technetwork/java/javase/downl ...

  8. 搭建基于docker 的redis分布式集群在docker for windows

    https://blog.csdn.net/xielinrui123/article/details/85104446 首先在docker中下载使用 docker pull redis:3.0.7do ...

  9. mac 下搭建Elasticsearch 5.4.3分布式集群

    一.集群角色 多机集群中的节点可以分为master nodes和data nodes,在配置文件中使用Zen发现(Zen discovery)机制来管理不同节点.Zen发现是ES自带的默认发现机制,使 ...

随机推荐

  1. Django restful

    1.restful api的规范 API与用户的通信协议,总是使用HTTPs协议. 域名  https://api.example.com                         尽量将API ...

  2. 反射与内置方法str del

    1.反射 用字符串来操作类或者对象的属性 class People:# country= 'china'# def __init__(self,name):# self.name= name## de ...

  3. C++程序设计方法3:派生类对象的构造和析构过程

    基类中的数据成员,通过继承成为派生类对象的一部分,需要在构造派生类对象的过程中调用基类构造函数来正确初始化: 若没有显示调用,则编译器会自动生成一个对基类的默认构造函数的调用. 若想要显示调用,则只能 ...

  4. JS面向对象之创建对象模式

    虽然Object构造函数或对象字面量都可以用来创建单个对象,但都有一个缺点,使用同一个接口来创建对象,会产生大量重复的代码,为解决这个问题,引出下列方法 1.工厂模式 抽象了创建具体对象的过程,用函数 ...

  5. Mac下hadoop运行word count的坑

    Mac下hadoop运行word count的坑 Word count体现了Map Reduce的经典思想,是分布式计算中中的hello world.然而博主很幸运地遇到了Mac下特有的问题Mkdir ...

  6. rest_framework中视图相关

    模型类的定义 # 定义图书模型类BookInfo class BookInfo(models.Model): btitle = models.CharField(max_length=20, verb ...

  7. 认证鉴权与API权限控制在微服务架构中的设计与实现(四)

    引言: 本文系<认证鉴权与API权限控制在微服务架构中的设计与实现>系列的完结篇,前面三篇已经将认证鉴权与API权限控制的流程和主要细节讲解完.本文比较长,对这个系列进行收尾,主要内容包括 ...

  8. Vue(十)生命周期

    Vue生命周期 vue实例从创建到销毁的过程,称为生命周期,共有八个阶段 <script> window.onload=function(){ let vm = new Vue({ el: ...

  9. python函数之协程与面向过程编程

    第一:协程 初步了解协程 def eater(): print('start to eat') while True: food=yield print('is eating food:%s'%foo ...

  10. EBS WEBADI 下载模板提示 Visual Basic 运行时错误 '91' 对象变量或With块变量未设置

    按以下的方法设置一遍EXCEL,并设置浏览器的安全属性.