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

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全