hbase和hadoop同样也分为单机版、伪分布式版和彻底分布式集群版本,这篇文件介绍如何搭建彻底分布式集群环境搭建。linux
hbase依赖于hadoop环境,搭建habase以前首先须要搭建好hadoop的彻底集群环境,所以看这篇文章以前须要先看个人上一篇文章:hadoop分布式集群搭建。本文中没有按照独立的zookeeper,使用了hbase自带的zookeeper。apache
环境准备vim
hbase软件包: http://mirror.bit.edu.cn/apache/hbase/1.3.1/hbase-1.3.1-bin.tar.gz
完成hadoop集群环境搭建
安装hbase服务器
首先在hadoop-master安装配置好以后,在复制到从节点网络
wget http://mirror.bit.edu.cn/apache/hbase/1.3.1/hbase-1.3.1-bin.tar.gzjvm
tar -xzvf hbase-1.3.1-bin.tar.gz -C /usr/local/分布式
mv hbase-1.3.1 hbase
配置环境变量vim /etc/profileoop
export HBASE_HOME=/usr/local/hbase
export PATH=$HBASE_HOME/bin:$PATH日志
source /etc/profile
修改系统变量ulimitserver
ulimit -n 10240
配置文件
hbase 相关的配置主要包括hbase-env.sh、hbase-site.xml、regionservers三个文件,都在 /usr/local/hbase/conf目录下面:
配置hbase-env.sh
vim hbase-env.sh
export JAVA_HOME=/usr/lib/jvm/jre-1.7.0-openjdk.x86_64
export HBASE_CLASSPATH=/usr/local/hbase/conf
export HBASE_MANAGES_ZK=true
export HBASE_HOME=/usr/local/hbase
export HADOOP_HOME=/usr/local/hadoop
export HBASE_LOG_DIR=/usr/local/hbase/logs
配置 hbase-site.xml
配置regionservers
vim /usr/local/hbase/conf/regionservers
hadoop-master
hadoop-slave1
hadoop-slave2
hadoop-slave3
复制hbase到从节点中
scp -r /usr/local/hbase hadoop-slave1:/usr/local/
scp -r /usr/local/hbase hadoop-slave2:/usr/local/
scp -r /usr/local/hbase hadoop-slave3:/usr/local/
启动hbase
启动仅在master节点上执行便可
~/hbase/bin/start-hbase.sh
启动后,master上进程和slave进程列表
master中的信息
[hadoop@master ~]$ jps
6225 Jps
2897 SecondaryNameNode # hadoop进程
2710 NameNode # hadoop master进程
3035 ResourceManager # hadoop进程
5471 HMaster # hbase master进程
2543 HQuorumPeer # zookeeper进程
salve中的信息
[hadoop@slave1 ~]$ jps
4689 Jps
2533 HQuorumPeer # zookeeper进程
2589 DataNode # hadoop slave进程
4143 HRegionServer # hbase slave进程
由于hbase依赖于hadoop,所以启动和中止都是须要按照顺序进行
若是安装了独立的zookeeper
启动顺序: hadoop-> zookeeper-> hbase
中止顺序:hbase-> zookeeper-> hadoop
使用自带的zookeeper
启动顺序: hadoop-> hbase
中止顺序:hbase-> hadoop
重启hbase
~/hbase/bin/stop-hbase.sh
~/hadoop/sbin/stop-all.sh
~/hadoop/sbin/start-all.sh
~/hbase/bin/start-hbase.sh
错误处理
在搭建的过程当中,报了这么一个错误,错误信息以下:
Unhandled: org.apache.hadoop.hbase.ClockOutOfSyncException: Server hadoop-slave3,16020,1500526355333
Caused by: org.apache.hadoop.hbase.ipc.RemoteWithExtrasException(org.apache.hadoop.hbase.ClockOutOfSyncException):
org.apache.hadoop.hbase.ClockOutOfSyncException:
Server hadoop-slave3,16020,1500526355333 has been rejected; Reported time is too far out of sync with
master. Time difference of 77348ms > max allowed of 30000ms
看大概的意思是主节点链接从节点超时了。可能有两方面的缘由,第1、linux服务器时间不一致致使,第2、因为网络其它缘由致使链接的时间超长。
解决方案:
第一个缘由,修改各服务器时间保持一致。最终的解决方案是:设置一个定时使用ntp从某个服务器定时同步时间
查看定时
crontab -l
编辑
crontab -e
0 /1 * * /usr/sbin/ntpdate 192.168.0.12;/sbin/hwclock -w
手动执行
/usr/sbin/ntpdate 192.168.0.12
第二个缘由,能够修改hbase默认的最大连接时间长一些。
HBase配置文件hbase-siter.xml中添加链接时长的属性