从Hbase 0.90.4到Hbase 0.94.6的CopyTable无效

时间:2013-09-05 05:06:07

标签: hbase

我正在尝试使用以下命令将表从Hbase 0.90复制到Hbase 0.04:

$ hbase org.apache.hadoop.hbase.mapreduce.CopyTable --peer.adr=ZKHOST:2181:/hbase --starttime=1378252486000 --endtime=1378338886000 --new.name=my_table my_table 

但是我收到了这个错误:

13/09/04 21:52:12 INFO mapred.JobClient: Running job: job_201305141438_0003
13/09/04 21:52:13 INFO mapred.JobClient:  map 0% reduce 0%
13/09/04 21:52:21 INFO mapred.JobClient: Task Id : attempt_201305141438_0003_m_000002_0, Status : FAILED
java.lang.IllegalArgumentException: Not a host:port pair: ?7805@hbase10.dc.yyy.nethbase10.dc.yyy.net,60020,1378354913021
        at org.apache.hadoop.hbase.HServerAddress.<init>(HServerAddress.java:60)
        at org.apache.hadoop.hbase.zookeeper.RootRegionTracker.dataToHServerAddress(RootRegionTracker.java:82)
        at org.apache.hadoop.hbase.zookeeper.RootRegionTracker.waitRootRegionLocation(RootRegionTracker.java:73)
        at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegion(HConnectionManager.java:786)
        at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegion(HConnectionManager.java:766)
        at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegionInMeta(HConnectionManager.java:895)
        at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegion(HConnectionManager.java:797)
        at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegion(HConnectionManag

我在新目标系统hbase01到hbase10中有10个主机。该脚本会自动选择1个主机,但我不确定为什么它会尝试使用类似'hbase10.dc.yyy.nethbase10.dc.yyy.net'的内容,这对我来说是错误的。

1 个答案:

答案 0 :(得分:1)

是复制表需要能够连接到两个集群。它们需要与RPC兼容。

  • 0.90 - &gt; 0.90
  • 0.92 - &gt; 0.92,0.94
  • 0.94 - &gt; 0.92,0.94
  • 0.96 - &gt; 0.96

也许导出/导入可以用来做你想要的东西?

https://hbase.apache.org/book/ops_mgt.html#export