Hadoop+HBase 安装配置

hadoop版本:hadoop-0.20.2 http://apache.etoak.com//hadoop/common/hadoop-0.20.2/

安装配置Hadoop请参考:http://booby325.iteye.com/admin/blogs/1309940


HBase版本:Hbase-0.90.3 http://apache.etoak.com//hbase/hbase-0.90.3/

Hbase书籍http://hbase.apache.org/book/book.html

 

1.将HBase解压后,放到Hadoop某一目录下。此处我们可以建立一个叫v20Habse的目录.[应该也可以不用这样做]

 

2.编辑{HBASE_HOME}/conf/hbase-env.sh文件

Java代码   收藏代码
  1. export JAVA_HOME=/usr/lib/jvm/java-6-sun    
  2. export HBASE_CLASSPATH=/home/daisy/hadoop-0.20.2 (可选,不写貌似也没问题)  
 

3.编辑{HBASE_HOME}/conf/hbase-site.xml 文件,增加

Xml代码   收藏代码
  1. <property>    
  2.     <name>hbase.rootdir</name>    
  3.     <value>hdfs://localhost:9000/hbase</value>       
  4. </property>    
  5. <property>    
  6.     <name>hbase.cluster.distributed</name>    
  7.     <value>true</value>    
  8. </property>  

注意:ip和端口号必须与hadoop中core-site.xml中fs.default.name中的ip和端口相同,否则会出错。此外,启动Hbase之前一定要确保hdfs中已经存在了hbase root路径。


4.替换Hbase中的jar包

    需要用{HADOOP_HOME}下的hadoop-0.20.2-core.jar 替换{HBASE_HOME}/lib目录下的hadoop-core-0.20-append-r1056497.jar. 如不替换,则Hbase启动时会因为hadoop和Hbase的客户端协议不一致而导致HMaster启动异常 

localhost: Exception in thread "main" org.apache.hadoop.ipc.RPC$VersionMismatch: Protocol org.apache.hadoop.hdfs.protocol.ClientProtocol version mismatch. (client = 42, server = 41)

 

还出现过,说找不到localhost:9000的错误。替换jar包则正常。

5. 使用HBase:

    启动: bin/start-hbase.sh

    停止: bin/stop-hbase.sh

    使用: bin/hbase shell 进入HBase命令行模式

Java代码   收藏代码
  1. hbase(main):004:0> create 'userlibrary', {NAME => 'lib', VERSION => 1}  
  2. 0 row(s) in 1.2460 seconds  
  3.   
  4. hbase(main):005:0> list  
  5. TABLE               
  6. userdata        
  7. userlibrary          
  8. 2 row(s) in 0.0220 seconds  

 

Note:

1. HBase的运行需要用到zookeeper,而hbase-0.90.3自带了zookeeper,所以可以使用hbase自带的zookeeper. 在conf/hbase-env.sh 文件中export HBASE_MANAGES_ZK=true表示使用hbase自带的zookeeper,如果不想使用其自带的zookeeper,自己下载包安装的话,该项设置为false. 如果自己安装zookeeper,启动及关闭先后顺序为:启动Hadoop—>启动ZooKeeper集群—>启动HBase—>停止HBase—>停止ZooKeeper集群—>停止Hadoop。

 

2. HBase启动时报错:

localhost: Exception in thread "main" org.apache.hadoop.ipc.RPC$VersionMismatch: Protocol org.apache.hadoop.hdfs.protocol.ClientProtocol version mismatch. (client = 42, server = 41)

是上面hbase安装时没有替换jar包的原因。

 

3. 运行时可能出现HBase一直等待dfs推出安全模式的情况,Waiting for dfs to exit safe mode

Safe mode is exited when the minimal replication condition is reached, plus an extension time of 30 seconds. The minimal replication condition is when 99.9% of the blocks in the whole filesystem meet their minimum replication level (which defaults to one, and is set by dfs.replication.min).

安全模式的退出前提 - 整个文件系统中的99.9%(默认是99.9%,可以通过dfs.safemode.threshold.pct设置)的Blocks达到最小备份级别(默认是1,可以通过hdf-site.xml中dfs.replication.min设置,比如0.5)。

 

或者用户可以通过hadoop dfsadmin -safemode value  来操作安全模式,参数value的说明如下:

enter - 进入安全模式

leave - 强制NameNode离开安全模式

get -  返回安全模式是否开启的信息

wait - 等待,一直到安全模式结束

你可能感兴趣的:(Hadoop+HBase 安装配置)