메뉴 건너뛰기

Cloudera, BigData, Semantic IoT, Hadoop, NoSQL

Cloudera CDH/CDP 및 Hadoop EcoSystem, Semantic IoT등의 개발/운영 기술을 정리합니다. gooper@gooper.com로 문의 주세요.


0. 아래와 같이 설정한다는 가정하에 작업을 진행한다.(ZK는 hbase가 관리하지 않도록 설정)

   master에 HMaster

   node1에 backup HMaster1, RegionServer

   node2에 backup HMaster2, RegionServer

   node3에 RegionServer

   node4에 RegionServer


1. hbase 0.98.12를 다운로드및 설치위치에 업로드

   http://www.eu.apache.org/dist/hbase/


2. 압축을 푼다.

   tar xvfz hbase-0.98.12-hadoop2-bin.tar.gz


3. soft link를 생성한다.

   ln -s hbase-0.98.12-hadoop2 hbase


3-1. 환경변수 설정(vi /etc/profile) 

   export HBASE_HOME=/usr/local/hbase 과

   export PATH=$PATH:$HBASE_HOME을 등록해준다.


4. hbase-env.sh 설정

  : JAVA_HOME과 HBASE_CLASSPATH의 commnet를 제거하고 

   아래와 같이 jdk가 설치된 경로와 hadoop이 설정파일의 위치를 지정해준다(hadoop변경사항을 hbase가 알기 위한 설정)

   zookeeper는 hbase가 관리하지 않게 설정한다.


  vi conf/hbase-env.sh

  export JAVA_HOME=/opt/jdk1.8.0_66

  export HBASE_CLASSPATH=$HADOOP_CONF_DIR

  export HBASE_MANAGES_ZK=false

  export HBASE_SSH_OPTS="-p 22"


* export JAVA_HOME=$JAVA_HOME로 설정하면 안되네??


5.conf/hbase-site.xml내용 수정

- zookeeper의 위치와 hbase의 data가 저장될 위치를 지정한다.


<configuration>

<!-- HDFS가 HA가 아닌경우 -->

<!--

  <property>

    <name>hbase.rootdir</name>

    <value>hdfs://master:9000/hbase</value>

  </property>

-->


<!-- HDFS가 HA로 구성된경우 -->

  <property>

    <name>hbase.rootdir</name>

    <value>hdfs://mycluster/hbase</value>

  </property>

<!-- mycluster는 hdfs-site.xml의 dfs.nameservices에 지정한 값을 사용한다 -->


  <property>

    <name>hbase.cluster.distributed</name>

    <value>true</value>

  </property>

  <property>

    <name>hbase.zookeeper.quorum</name>

    <value>master:2181,node1:2181,node2:2181</value>

  </property>

</configuration>


5-1. 로그 경로 변경

vi /usr/local/hbase/conf/hbase-env.sh

# Where log files are stored.  $HBASE_HOME/logs by default.

# export HBASE_LOG_DIR=${HBASE_HOME}/logs의 주석을 풀고 아래와 같이 변경함

 export HBASE_LOG_DIR=/logs/hbase/logs


6. regionserver가 될 node를 지정한

vi conf/regionservers

node1

node2

node3

node4


7. HMaster의 백업용으로 사용할 backup서버를 지정한다.(파일이 없으면 생성해준다)

vi conf/backup-masters

node1

node2


8. 각서버에 hbase전체를 복사후 링크를 생성한다.

가. 복사

  scp -r -P 22 hbase-0.98.12-hadoop2 root@node1:$HOME

  scp -r -P 22 hbase-0.98.12-hadoop2 root@node2:$HOME

  scp -r -P 22 hbase-0.98.12-hadoop2 root@node3:$HOME

  scp -r -P 22 hbase-0.98.12-hadoop2 root@node4:$HOME

나. 링크생성

  ln -s hbase-0.98.12-hadoop2 hbase


9. hadoop환경설정 정보를 hbase가 사용할 수 있게 설정(hbase가 설치된 모든 서버에서 실행)

* hadoop의 변경사항을 hbase가 알 수 있게 하는 방법은 2가지가 더 있다.

 가. hbase설치 위치의 conf폴더 밑에 hdfs-site.xml, core-site.xml, yarn-site.xml등 3개의 파일에 대한 symbolic links를

  생성한다.(hbase가 설치된곳의 conf폴더 밑에서 "ln -s $HADOOP_HOME/etc/hadoop/hdfs-site.xml hdfs-site.xml"등을 실행함)

  (

   root@master:~/hbase/conf# ln -s $HADOOP_HOME/etc/hadoop/hdfs-site.xml hdfs-site.xml 

   root@master:~/hbase/conf# ln -s $HADOOP_HOME/etc/hadoop/core-site.xml core-site.xml

   root@master:~/hbase/conf# ln -s $HADOOP_HOME/etc/hadoop/yarn-site.xml yarn-site.xml

)

 나. 몇개 안되는 설정값(예, dfs.replication.factor)은 hbase-site.xml에 설정값을 직접넣는다.


10. master서버에서 start시켜줌(master에서 기동시키면 나머지 데몬은 hbase가 자동으로 올려준댜)

root@master:bin# start-hbase.sh

starting master, logging to /usr/local/hbase/logs/hbase-root-master-master.out

node3: starting regionserver, logging to /usr/local/hbase/bin/../logs/hbase-root-regionserver-node3.out

node4: starting regionserver, logging to /usr/local/hbase/bin/../logs/hbase-root-regionserver-node4.out

node1: starting regionserver, logging to /usr/local/hbase/bin/../logs/hbase-root-regionserver-node1.out

node2: starting regionserver, logging to /usr/local/hbase/bin/../logs/hbase-root-regionserver-node2.out

node1: starting master, logging to /usr/local/hbase/bin/../logs/hbase-root-master-node1.out

node2: starting master, logging to /usr/local/hbase/bin/../logs/hbase-root-master-node2.out


* stop-hbase.sh은 HMaster데몬이 떠있는 곳에서 실행해야함

(stopping hbase: /tmp/hbase-hadoop-master.pid: No such file or directory 오류발생)


* regionserver를 수동으로 기동하는 방법

./bin/hbase-daemon.sh start regionserver


11. 모니터링

* hbase 0.98.x이하인 경우

HMaster Info Web UI : http://192.168.10.100:60010

Region Server : http://192.168.10.100:60030


* hbase 0.98.x이상의 버젼에서는 포트가 아래와 같이 변경됨

HMaster Info Web UI : http://192.168.10.100:16010

Region Server : http://192.168.10.100:16030


* start-hbase.sh에서 regionserver가 기동하지 못하고 "org.apache.hadoop.hbase.ClockOutOfSyncException: org.apache.hadoop.hbase.ClockOutOfSyncException"오류가 발생하면 master와 regionserver에서 "rdate -s time.bora.net" 혹은 "ntpdate time.bora.net"를 실행하여 시간을 맞추고 start-hbase.sh을 실행해준다.


12. hbase test
가. 실행
   bin/hbase shell

나. test 테이블생성
hbase(main):002:0> create 'test', 'cf'
0 row(s) in 1.5750 seconds
=> Hbase::Table - test

다. list
다. put 'test', 'rowkey1','cf:a', 'test_value'
라. scan 'test'
마. describe 'test'

* hbase shell을 이용한 간단한 테스트는 https://www.gooper.com/ss/index.php?mid=bigdata&category=2788&page=2&document_srl=2912 를 참조할것

번호 제목 날짜 조회 수
124 Nodes of the cluster (unhealthy)중 1/1 log-dirs are bad: 오류 해결방법 2015.05.17 1303
123 secureCRT에서 backspace키가 작동하지 않는 경우 해결방법 2015.05.11 1584
122 hbase가 기동시키는 zookeeper에서 받아드리는 ip가 IPv6로 사용되는 경우가 있는데 이를 IPv4로 강제적용하는 방법 2015.05.08 1261
121 hbase CustomFilter만들기 (0.98.X이상) 2015.05.08 1123
120 znode /hbase recursive하게 지우기 2015.05.06 1368
119 java.lang.IllegalArgumentException: Does not contain a valid host:port authority: master 오류해결방법 2015.05.06 616
118 hadoop 2.6.0 기동(에코시스템 포함)및 wordcount 어플리케이션을 이용한 테스트 2015.05.05 4079
117 oozie 4.1 설치 - maven을 이용한 source compile on hadoop 2.5.2 with postgresql 9.3 2015.04.30 1370
116 hive 0.13.1 설치 + meta정보는 postgresql 9.3에 저장 2015.04.30 1025
» HBase 0.98.12(1.2.5) for hadoop2 설치-5대에 완전분산모드 (HDFS HA상테) 2015.04.29 1487
114 Hadoop - 클러스터 세팅및 기동 2015.04.28 941
113 zookeeper 3.4.6 설치(3대) 2015.04.28 1752
112 WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable원인 2015.04.27 1169
111 bananapi 5대(ubuntu계열 리눅스)에 yarn(hadoop 2.6.0)설치하기-ResourceManager HA/HDFS HA포함, JobHistory포함 2015.04.24 19611
110 scan의 startrow, stoprow지정하는 방법 2015.04.08 1221
109 SASL configuration failed: javax.security.auth.login.LoginException: java.lang.NullPointerException 오류 해결방법 2015.04.02 1079
108 kafka의 re-balance를 이용하여 consumer를 multi thread로 돌려서 topic의 partitions을 활용 2015.03.31 1505
107 Using The ZooKeeper CLI에서 zkCli의 위치 2014.11.02 1578
106 [번역] solr 검색 엔진 튜토리얼 2014.10.07 765
105 solr vs elasticsearch 비교2 2014.09.29 1540
위로