知乎专栏 |
注意:Apache Hbase 不能使用 OpenJDK 启动,需要去 Oracle 网站下载 Server JRE
如果你是第一次安装Hbase,建议你从单机安装开始,这样成功率比较高,不会受挫。Hbase 不比关系型数据库复杂,只是安装比较麻烦,一旦安装号使用起来还是很容易上手的,请直接粘贴复制下面的命令即可完成安装:
cd /usr/local/src wget http://mirrors.hust.edu.cn/apache/hbase/stable/hbase-1.2.6-bin.tar.gz tar zxf hbase-1.2.6-bin.tar.gz cp hbase-1.2.6/conf/hbase-site.xml{,.original} mv hbase-1.2.6 /srv/apache-hbase-1.2.6 ln -s /srv/apache-hbase-1.2.6 /srv/apache-hbase cp /srv/apache-hbase/conf/hbase-env.sh{,.original} cat > /srv/apache-hbase/conf/hbase-env.sh <<EOF export JAVA_HOME=/srv/java #export HBASE_CLASSPATH= export HBASE_MANAGES_ZK=true EOF cat > /srv/hbase/conf/hbase-site.xml <<EOF <?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="configuration.xsl"?> <configuration> <property> <name>hbase.rootdir</name> <value>file:///tmp/hbase-${user.name}</value> </property> </configuration> EOF
启动 Apache Hbase
/srv/apache-hbase/bin/start-hbase.sh
进入 Hbase shell
/srv/apache-hbase/bin/hbase shell
关闭 Hbase
/srv/apache-hbase/bin/stop-hbase.sh
单机模式基本可能满足我们的学习需要,但无法满足更复杂的需求,例如集成Hive等其他软件,这时我们就需要借助 Hadoop 的HDFS功能实现与其他软件的集成。所谓的伪分布式,就是只有一个Hbase节点,即Master。
这里我假设 Hadoop 已经正确安装,无论你采用什么模式只要能提供 hdfs 服务处即可。Hadoop 安装可以参考作者的相关文档。
首先编辑 conf/hbase-site.xml 配置文件,增加以下配置:
<property> <name>hbase.cluster.distributed</name> <value>true</value> </property>
hbase.cluster.distributed 属性值设置为 true HBase 将运行于分布式模式
然后配置 hbase.rootdir 属性值,指向 HDFS 地址。
<property> <name>hbase.rootdir</name> <value>hdfs://localhost:9000/hbase</value> </property>
现在启动 Hbase , 如果正常使用 jps 可以下面三个线程
[hadoop@netkiller conf]$ su - hadoop -c "/srv/apache-hbase/bin/start-hbase.sh" [hadoop@netkiller conf]$ jps | egrep "(HMaster|HRegionServer|HQuorumPeer)"
如果启动正常,你将会看到 HDFS 中的 Hbase目录。
[hadoop@netkiller ~]$ /srv/hadoop/bin/hdfs dfs -ls /hbase Found 7 items drwxr-xr-x - hadoop supergroup 0 2017-06-28 21:55 /hbase/.tmp drwxr-xr-x - hadoop supergroup 0 2017-06-28 21:55 /hbase/MasterProcWALs drwxr-xr-x - hadoop supergroup 0 2017-06-28 21:55 /hbase/WALs drwxr-xr-x - hadoop supergroup 0 2017-06-28 21:55 /hbase/data -rw-r--r-- 3 hadoop supergroup 42 2017-06-28 21:55 /hbase/hbase.id -rw-r--r-- 3 hadoop supergroup 7 2017-06-28 21:55 /hbase/hbase.version drwxr-xr-x - hadoop supergroup 0 2017-06-28 21:55 /hbase/oldWALs