Linux安装Hbase(CentOS7+Hbase1.4.9+Hadoop2.8.0)

2023-10-23 23:32

本文主要是介绍Linux安装Hbase(CentOS7+Hbase1.4.9+Hadoop2.8.0),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

https://blog.csdn.net/pucao_cug/article/details/72229223


1下载和解压缩

         1.1下载

         1.2解压缩

2 配置

         2.1环境变量配置

         2.2 conf目录下的配置

                  2.2.1修改hbase-env.sh文件

                  2.2.2修改配置文件hbase-site.xml

                  2.2.3修改regionservers文件

3启动和测试

           3.1启动

           3.2测试

                  3.2.1用浏览器访问Hbase状态信息

                 3.2.2启动hbase的命令行

关键词:Linux   CentOS    Hadoop    Hbase  Zookeeper  JAVA

版本号:CentOS7   Hadoop2.8.0     Hbase1.2.5   Zookeeper3.4.10   JDK1.8

      说明:Hbase可以在Hadoop集群的某些机器(一台也可以,例如选择namenode节点来安装)上安装,也可以全部机器上都安装。Hbase是依赖Hadoop和Zookeeper的,所以在安装Hbase之前,请先安装Hadoop和Zookeeper,Zookeeper可以是单机的也可以是集群,Hadoop的安装请参考博文:

      http://blog.csdn.net/pucao_cug/article/details/71698903

      Zookeeper的安装请参考:

      http://blog.csdn.net/pucao_cug/article/details/72228973    

1  下载和解压缩

1.1  下载

        可以直接在CentOS上用wget下载,也可以在本地下载之后再用工具上载到CetnOS上。

目前稳定的版本是1.2.5,所以这里也是安装1.2.5。

       下载地址:

http://mirror.bit.edu.cn/apache/hbase/stable/

      如图:

      

1.2  解压缩   

      使用root账号登录,在opt命令下新建一个没hbase的目录,把压缩包放到该目录下

     如图:

    

      进入到该目录内然:

cd     /opt/hbase

       执行解压缩命令:

tar   -xvf    hbase-1.2.5-bin.tar.gz

2  配置

2.1  环境变量配置

     在/etc/profile文件中主要增加的内容是:

ZK_HOME=/opt/zookeeper/zookeeper-3.4.10
HBASE_HOME=/opt/hbase/hbase-1.2.5

     PATH中增加: 

$HBASE_HOME/bin:$ZK_HOME/bin

     我的/etc/profile文件中主要的配置:

export  JAVA_HOME=/opt/java/jdk1.8.0_121
export  HADOOP_HOME=/opt/hadoop/hadoop-2.8.0
export  HADOOP_CONF_DIR=${HADOOP_HOME}/etc/hadoop
export  HADOOP_COMMON_LIB_NATIVE_DIR=${HADOOP_HOME}/lib/native
export  HADOOP_OPTS="-Djava.library.path=${HADOOP_HOME}/lib"
export  HIVE_HOME=/opt/hive/apache-hive-2.1.1-bin
export  HIVE_CONF_DIR=${HIVE_HOME}/conf
export  SQOOP_HOME=/opt/sqoop/sqoop-1.4.6.bin__hadoop-2.0.4-alpha
export  HBASE_HOME=/opt/hbase/hbase-1.2.5
export  ZK_HOME=/opt/zookeeper/zookeeper-3.4.10
export  CLASS_PATH=.:${JAVA_HOME}/lib:${HIVE_HOME}/lib:$CLASS_PATH
exportPATH=.:${JAVA_HOME}/bin:${HADOOP_HOME}/bin:${HADOOP_HOME}/sbin:${SPARK_HOME}/bin:${ZOOKEEPER_HOME}/bin:${HIVE_HOME}/bin:${SQOOP_HOME}/bin:${HBASE_HOME}:${ZK_HOME}/bin:$PATH

       说明:环境变量配置完后,要执行source /etc/profile才能生效。

2.2  conf目录下的配置

       对/opt/hbase/hbase-1.2.5/conf目录下的一系列文件做配置。使用命令进入到该目录:

      cd      /opt/hbase/hbase-1.2.5/conf

2.2.1 修改hbase-env.sh文件

        在/opt/hbase/hbase-1.2.5/conf/hbase-env.sh中增加内容:

export JAVA_HOME=/opt/java/jdk1.8.0_121
export HADOOP_HOME=/opt/hadoop/hadoop-2.8.0
export HBASE_HOME=/opt/hbase/hbase-1.2.5
export HBASE_CLASSPATH=/opt/hadoop/hadoop-2.8.0/etc/hadoop
export HBASE_PID_DIR=/root/hbase/pids
export HBASE_MANAGES_ZK=false

如图:

    

2.2.2 修改配置文件hbase-site.xml

      在该配置文件中可以给hbase配置一个临时目录,这里指定为mkdir /root/hbase/tmp,先执行命令创建文件夹。

执行新建目录的命令:

mkdir  /root/hbase
mkdir  /root/hbase/tmp
mkdir  /root/hbase/pids

    在<configuration>节点内增加以下配置:

<property><name>hbase.rootdir</name><value>hdfs://hserver1:9000/hbase</value><description>The directory shared byregion servers.</description>
</property>
<property><name>hbase.zookeeper.property.clientPort</name><value>2181</value><description>Property from ZooKeeper'sconfig zoo.cfg. The port at which the clients will connect.</description>
</property>
<property><name>zookeeper.session.timeout</name><value>120000</value>
</property>
<property><name>hbase.zookeeper.quorum</name><value>hserver1,hserver2,hserver3</value>
</property>
<property><name>hbase.tmp.dir</name><value>/root/hbase/tmp</value>
</property>
<property><name>hbase.cluster.distributed</name><value>true</value>
</property>

修改完成后,我的hbase-site.xml内容是:

  

<?xmlversion="1.0"?>
<?xml-stylesheettype="text/xsl" href="configuration.xsl"?>
<!--
/****Licensed to the Apache Software Foundation (ASF) under one* ormore contributor license agreements.  Seethe NOTICE file*distributed with this work for additional information*regarding copyright ownership.  The ASFlicenses this file* toyou under the Apache License, Version 2.0 (the*"License"); you may not use this file except in compliance*with the License.  You may obtain a copyof the License at**    http://www.apache.org/licenses/LICENSE-2.0**Unless required by applicable law or agreed to in writing, software*distributed under the License is distributed on an "AS IS" BASIS,*WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.*See the License for the specific language governing permissions and*limitations under the License.*/
-->
<configuration>
<property><name>hbase.rootdir</name><value>hdfs://hserver1:9000/hbase</value><description>The directory shared byregion servers.</description>
</property>
<property><name>hbase.zookeeper.property.clientPort</name><value>2181</value><description>Property from ZooKeeper'sconfig zoo.cfg. The port at which the clients will connect.</description>
</property>
<property><name>zookeeper.session.timeout</name><value>120000</value>
</property>
<property><name>hbase.zookeeper.quorum</name><value>hserver1,hserver2,hserver3</value>
</property>
<property><name>hbase.tmp.dir</name><value>/root/hbase/tmp</value>
</property>
<property><name>hbase.cluster.distributed</name><value>true</value>
</property>

</configuration>

2.2.3  修改regionservers文件

将该文件内容修改为:

hserver1
hserver2
hserver3

如图:

     

3  启动和测试

3.1 启动

         Hbase是基于hadoop提供的分布式文件系统的,所以启动Hbase之前,先确保hadoop在正常运行,另外Hbase还依赖于zookkeeper,本来我们可以用hbase自带的zookeeper,但是我们上面的配置启用的是我们自己的zookeeper集群,所以在启动hbase前,还要确保zokeeper已经正常运行。

       Hbase可以只在hadoop的某个namenode节点上安装,也可以在所有的hadoop节点上安装,但是启动的时候只需要在一个节点上启动就行了,本例中,我在hserver1、hserver2、hserver3都安装了Hbase,启动的时候只需要在hserver1上启动就OK。

      在hserver1上执行命令,进入到Hbase的bin目录内,命令是:

cd     /opt/hbase/hbase-1.2.5/bin

       执行命令启动Hbase,命令是:

./start-hbase.sh

如图:

      

      输出信息是:

[root@hserver1~]# cd  /opt/hbase/hbase-1.2.5/bin
[root@hserver1bin]# ./start-hbase.sh
starting master,logging to /opt/hbase/hbase-1.2.5/logs/hbase-root-master-hserver1.out
Java HotSpot(TM)64-Bit Server VM warning: ignoring option PermSize=128m; support was removed in8.0
Java HotSpot(TM)64-Bit Server VM warning: ignoring option MaxPermSize=128m; support was removedin 8.0
hserver3:starting regionserver, logging to /opt/hbase/hbase-1.2.5/logs/hbase-root-regionserver-hserver3.out
hserver2:starting regionserver, logging to/opt/hbase/hbase-1.2.5/logs/hbase-root-regionserver-hserver2.out
hserver2: JavaHotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=128m; supportwas removed in 8.0
hserver2: JavaHotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=128m; supportwas removed in 8.0
hserver3: JavaHotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=128m; supportwas removed in 8.0
hserver3: Java HotSpot(TM)64-Bit Server VM warning: ignoring option MaxPermSize=128m; support was removedin 8.0
hserver1:starting regionserver, logging to/opt/hbase/hbase-1.2.5/logs/hbase-root-regionserver-hserver1.out
[root@hserver1bin]#

3.2  测试

3.2.1  用浏览器访问Hbase状态信息

      直接访问地址:http://192.168.27.139:16030/

如图:

      

3.2.2 启动hbase的命令行

      执行命令,进入到Hbase的bin目录内,命令是:

cd  /opt/hbase/hbase-1.2.5/bin

      执行命令启动Hbase命令行窗口,命令是:

./hbase  shell

如图:

      

  完整的输出是:

  

[root@hserver1 bin]# cd  /opt/hbase/hbase-1.2.5/bin
[root@hserver1 bin]# ./hbase  shell
2017-05-15 17:52:55,411 WARN  [main] util.NativeCodeLoader: Unable to loadnative-hadoop library for your platform... using builtin-java classes whereapplicable
SLF4J: Class path contains multiple SLF4Jbindings.
SLF4J: Found binding in[jar:file:/opt/hbase/hbase-1.2.5/lib/slf4j-log4j12-1.7.5.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in[jar:file:/opt/hadoop/hadoop-2.8.0/share/hadoop/common/lib/slf4j-log4j12-1.7.10.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Seehttp://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type[org.slf4j.impl.Log4jLoggerFactory]
HBase Shell; enter 'help<RETURN>' forlist of supported commands.
Type "exit<RETURN>" toleave the HBase Shell
Version 1.2.5,rd7b05f79dee10e0ada614765bb354b93d615a157, Wed Mar  1 00:34:48 CST 2017

hbase(main):001:0>

      在hbase命令行模式下,可以输入一系列hbase命令,进行测试

输入:status

     如图:

     

    完整的输出是:

hbase(main):001:0> status
1 active master, 0 backup masters, 3servers, 0 dead, 0.6667 average load

hbase(main):002:0>

      如果要退出Hbase命令行模式的话,输入:exit

     如图:

     

这篇关于Linux安装Hbase(CentOS7+Hbase1.4.9+Hadoop2.8.0)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/271192

相关文章

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

Linux之systemV共享内存方式

《Linux之systemV共享内存方式》:本文主要介绍Linux之systemV共享内存方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、工作原理二、系统调用接口1、申请共享内存(一)key的获取(二)共享内存的申请2、将共享内存段连接到进程地址空间3、将

Win安装MySQL8全过程

《Win安装MySQL8全过程》:本文主要介绍Win安装MySQL8全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Win安装mysql81、下载MySQL2、解压文件3、新建文件夹data,用于保存数据库数据文件4、在mysql根目录下新建文件my.ini

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

Maven如何手动安装依赖到本地仓库

《Maven如何手动安装依赖到本地仓库》:本文主要介绍Maven如何手动安装依赖到本地仓库问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载依赖二、安装 JAR 文件到本地仓库三、验证安装四、在项目中使用该依赖1、注意事项2、额外提示总结一、下载依赖登

CentOS7更改默认SSH端口与配置指南

《CentOS7更改默认SSH端口与配置指南》SSH是Linux服务器远程管理的核心工具,其默认监听端口为22,由于端口22众所周知,这也使得服务器容易受到自动化扫描和暴力破解攻击,本文将系统性地介绍... 目录引言为什么要更改 SSH 默认端口?步骤详解:如何更改 Centos 7 的 SSH 默认端口1

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文