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을 실행해준다.
0 row(s) in 1.5750 seconds