Hbase安装部署

一、Hbase简介


HBase是Apache Hadoop的数据库,能够对大型数据提供随机、实时的读写访问,是Google的BigTable的开源实现。HBase的目标是存储并处理大型的数据,更具体地说仅用普通的硬件配置,能够处理成千上万的行和列所组成的大型数据库。
HBase是一个开源的、分布式的、多版本的、面向列的存储模型。可以直接使用本地文件系统也可使用Hadoop的HDFS文件存储系统。为了提高数据的可靠性和系统的健壮性,并且发挥HBase处理大型数据的能力,还是使用HDFS作为文件存储系统更佳。另外,HBase存储的是松散型数据,具体来说,HBase存储的数据介于映射(key/value)和关系型数据之间。如下图所示,HBase存储的数据从逻辑上看就是一张很大的表,并且它的数据列可以根据需要动态增加。每一个cell中的数据又可以有多个版本(通过时间戳来区别),从下图来看,HBase还具有“向下提供存储,向上提供运算”的特点。

二、Hbase安装概述


  1. 配置hosts,确保涉及的主机名均可以解析为ip。
    若已经安装部署好hadoop,则此步已经完成。
  2. 编辑hbase-env.xml。
  3. 编辑hbase-site.xml。
  4. 编辑regionservers文件。
  5. 把Hbase复制到其它节点。
  6. 启动Hbase。
  7. 验证启动。

三、安装步骤


  1. 配置hosts,确保涉及的主机名均可以解析为ip。
    [hadoop@master ~]$ cat /etc/hosts
    10.10.18.229 master
    10.10.18.221 slave01
    10.10.19.231 slave02
    10.10.19.232 slave03
    10.10.18.230 slave04
    
    
  2. 下载安装包并解压
    [hadoop@master ~]$ wget http://www-us.apache.org/dist/hbase/stable/hbase-1.2.5-bin.tar.gz
    [hadoop@master ~]$ tar xvf hbase-1.2.5-bin.tar.gz
    
  3. 编辑环境变量
    #添加
    [hadoop@master hbase-1.2.5]$ vim ~/.bash_profile 
    export HBASE_HOME=/home/hadoop/hbase-1.2.5
    export PATH=$PATH:$HBASE_HOME/bin
    
  4. 编辑hbase-env.xml
    主要是添加JAVA_HOME环境变量
    export JAVA_HOME=/usr/lib/jvm/java-1.7.0-openjdk-1.7.0.79.x86_64
    
  5. 编辑hbase-site.xml
    <configuration>
        <property>
            <name>hbase.rootdir</name> #设置hbase数据库存放数据的目录
            <value>hdfs://master:9000/hbase</value>
        </property>
        <property>
        <name>hbase.cluster.distributed</name>  #打开hbase分布模式
            <value>true</value>
        </property>
        <property>
            <name>hbase.master</name> #指定hbase集群主控节点
            <value>master:60000</value>
        </property>
        <property>
            <name>hbase.zookeeper.quorum</name>
            <value>master,slave01,slave02,slave03,slave04</value> #指定zookeeper集群节点名,因为是由zookeeper表决算法决定的
        </property>
        <property>
            <name>hbase.zookeeper.property.dataDir</name> #指zookeeper集群data目录
            <value>/home/hadoop/hbase-1.2.5/zookeeper</value>
        </property>
    </configuration>
    
  6. 编辑regionservers文件
    [hadoop@master conf]$ cat regionservers 
    slave01
    slave02
    slave03
    slave04
    
  7. 将修改的hbase目录同步其它节点
    [hadoop@master ~]$ scp -r hbase-1.2.5 slave01:~/
    [hadoop@master ~]$ scp -r hbase-1.2.5 slave02:~/
    [hadoop@master ~]$ scp -r hbase-1.2.5 slave03:~/
    [hadoop@master ~]$ scp -r hbase-1.2.5 slave04:~/
    
  8. 启动/关闭Hbase数据库集群
    #启动hbase之前必需检查hadoop是否已经启动
    [hadoop@master ~]$ hdfs dfsadmin -report |less
    Configured Capacity: 9508728098816 (8.65 TB)
    Present Capacity: 7003711967546 (6.37 TB)
    DFS Remaining: 5616475771026 (5.11 TB)
    DFS Used: 1387236196520 (1.26 TB)
    DFS Used%: 19.81%
    Under replicated blocks: 137
    Blocks with corrupt replicas: 0
    Missing blocks: 0
    Missing blocks (with replication factor 1): 0
    
    -------------------------------------------------
    Live datanodes (4):
    ...
    #启动Hbase集群
    [hadoop@master conf]$ start-hbase.sh 
    slave01: starting zookeeper, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-zookeeper-slave01.out
    slave03: starting zookeeper, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-zookeeper-slave03.out
    master: starting zookeeper, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-zookeeper-master.out
    slave04: starting zookeeper, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-zookeeper-slave04.out
    slave02: starting zookeeper, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-zookeeper-slave02.out
    starting master, logging to /home/hadoop/hbase-1.2.5/logs/hbase-hadoop-master-master.out
    slave01: starting regionserver, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-regionserver-slave01.out
    slave03: starting regionserver, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-regionserver-slave03.out
    slave02: starting regionserver, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-regionserver-slave02.out
    slave04: starting regionserver, logging to /home/hadoop/hbase-1.2.5/bin/../logs/hbase-hadoop-regionserver-slave04.out
    #可以看到在master上多了两个进程HQuorumPeer和HMaster
    [hadoop@master conf]$ jps
    13154 Jps
    46355 ResourceManager
    9736 RunJar
    45787 NameNode
    46090 SecondaryNameNode
    12668 HMaster
    8641 JobHistoryServer
    12559 HQuorumPeer
    #在slave节点上也多了两个进程:HQuorumPeer和HRegionServer
    [hadoop@master conf]$ ssh slave01
    Last login: Thu May  4 17:31:40 2017 from master
    [hadoop@slave01 ~]$ jps
    13244 DataNode
    15944 NodeManager
    5688 HQuorumPeer
    6057 Jps
    5800 HRegionServer
    
  9. 查看Hbase状态
    #进入Hbase shell
    [hadoop@master conf]$ hbase shell
    SLF4J: Class path contains multiple SLF4J bindings.
    SLF4J: Found binding in [jar:file:/home/hadoop/hbase-1.2.5/lib/slf4j-log4j12-1.7.5.jar!/org/slf4j/impl/StaticLoggerBinder.class]
    SLF4J: Found binding in [jar:file:/home/hadoop/hadoop-2.7.3/share/hadoop/common/lib/slf4j-log4j12-1.7.10.jar!/org/slf4j/impl/StaticLoggerBinder.class]
    SLF4J: See http://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>' for list of supported commands.
    Type "exit<RETURN>" to leave the HBase Shell
    Version 1.2.5, rd7b05f79dee10e0ada614765bb354b93d615a157, Wed Mar  1 00:34:48 CST 2017
    #可以看到,当前存在一个活动master主机,3台regionserver主机,貌似还少一台。后来发现是因为regionserver主机时间与master主机不同步,时间比master主机早了导致的。
    hbase(main):001:0> status
    1 active master, 0 backup masters, 3 servers, 0 dead, 0.3333 average load
    #安装配置ntp服务后,4个regionserver都存在了
    hbase(main):001:0> status
    1 active master, 0 backup masters, 4 servers, 0 dead, 0.5000 average load
    
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容