You can check snapshot state if it is healthy or not using below command.

On Thu, Sep 24, 2015 at 2:55 PM, 核弹头す <510688...@qq.com> wrote:

> Hi all,
>
>
> I am using hive to query on base snapshot. But I got the following  error:
>
> FAILED: IllegalArgumentException
> org.apache.hadoop.hbase.snapshot.CorruptedSnapshotException: Couldn't read
> snapshot info
> from:/tmp/hbase-huser/hbase/.hbase-snapshot/test_table_snap0/.snapshotinfo
>
> The following is the steps that I do:
>
> 1, on the hbase we already have an table: test_table. And I use command: 
> snapshot
> ‘test_table’ ,’test_table_snap0’   to create a  snapshot。
>
> 2,on the hive create an external table like:
>
> CREATE EXTERNAL TABLE `test_table_snapshot`(
>
>   `id` int,
>
>   `alias` string,
>
>   `kdt_id` int,
>
>   `created_time` string,
>
>   `update_time` string,
>
>   `title` string,
>
>   `price` bigint,
>
>   `goods_platform` int,
>
>   `buy_url` string,
>
>   `class1` int,
>
>   `class2` string,
>
>   `goods_type` tinyint,
>
>   `sold_status` tinyint,
>
>   `is_display` tinyint,
>
>   `is_delete` tinyint,
>
>   `num` bigint,
>
>   `buy_way` boolean,
>
>   `source` tinyint,
>
>   `content` string,
>
>   `picture` string,
>
>   `is_virtual` tinyint)
>
> ROW FORMAT SERDE
>
>   'org.apache.hadoop.hive.hbase.HBaseSerDe'
>
> STORED BY
>
>   'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
>
> WITH SERDEPROPERTIES (
>
>   'field.delim'='\u0001',
>
>
> 'hbase.columns.mapping'=':key,cf1:alalis,cf1:kdt_id,cf1:created_time,cf1:update_time,cf1:title,cf1:price,cf1:goods_platform,cf1:buy_url,cf1:class1,cf1:class2,cf1:goods_type,cf1:sold_stattus,cf1:is_display,cf1:is_delete,cf1:num,cf1:buy_way,cf1:source,cf1:content,cf1:picture,cf1:is_virtual',
>
>   'line.delim'='\n',
>
>   'serialization.format'='\u0001')
>
> TBLPROPERTIES (
>
>   ‘hbase.table.name'='test_table')
>
>
> 4, on Hive, execute “select * from test_table_snapshot”,  then I get the
> above error.
>
>
> I have set the “hive.hbase.snapshot.restoredir” value which is same as the
> root dir on hbase, and I also set the zookeep server. I checked the base
> root directory on hdfs and I can see the snapshot files. But when I use the
> above query on hive. it seems that the base.tmp.dir is used to find the
> snapshot info. BTW, if I directly query on hbase, there is no problem. I do
> not know what happened?
>
>
> The following is the hive error log:
>
> FAILED: SemanticException
> org.apache.hadoop.hbase.snapshot.CorruptedSnapshotException: Couldn't read
> snapshot info from:/tmp
> /hbase-huser/hbase/.hbase-snapshot/goods_v3_hbase_snap0/.snapshotinfo
>
> org.apache.hadoop.hive.ql.parse.SemanticException:
> org.apache.hadoop.hbase.snapshot.CorruptedSnapshotException: Couldn't read
> snapshot info from:/tmp
> /hbase-huser/hbase/.hbase-snapshot/goods_v3_hbase_snap0/.snapshotinfo
>
>         at
> org.apache.hadoop.hive.ql.optimizer.SimpleFetchOptimizer.transform(SimpleFetchOptimizer.java:117)
>
>         at
> org.apache.hadoop.hive.ql.optimizer.Optimizer.optimize(Optimizer.java:182)
>
>         at
> org.apache.hadoop.hive.ql.parse.SemanticAnalyzer.analyzeInternal(SemanticAnalyzer.java:
> 10207)
>
>         at
> org.apache.hadoop.hive.ql.parse.CalcitePlanner.analyzeInternal(CalcitePlanner.java:192)
>
>         at
> org.apache.hadoop.hive.ql.parse.BaseSemanticAnalyzer.analyze(BaseSemanticAnalyzer.java:222)
>
>         at org.apache.hadoop.hive.ql.Driver.compile(Driver.java:421)
>
>         at org.apache.hadoop.hive.ql.Driver.compile(Driver.java:307)
>
>         at
> org.apache.hadoop.hive.ql.Driver.compileInternal(Driver.java:1112)
>
>         at org.apache.hadoop.hive.ql.Driver.runInternal(Driver.java:1160)
>
>         at org.apache.hadoop.hive.ql.Driver.run(Driver.java:1049)
>
>         at org.apache.hadoop.hive.ql.Driver.run(Driver.java:1039)
>
>         at
> org.apache.hadoop.hive.cli.CliDriver.processLocalCmd(CliDriver.java:207)
>
>         at
> org.apache.hadoop.hive.cli.CliDriver.processCmd(CliDriver.java:159)
>
>         at
> org.apache.hadoop.hive.cli.CliDriver.processLine(CliDriver.java:370)
>
>         at
> org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:754)
>
>         at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:675)
>
>         at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:615)
>
>         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>
>         at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
>
>         at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
>
>         at java.lang.reflect.Method.invoke(Method.java:606)
>
>         at org.apache.hadoop.util.RunJar.run(RunJar.java:221)
>
>         at org.apache.hadoop.util.RunJar.main(RunJar.java:136)
>
> Caused by: java.lang.IllegalArgumentException:
> org.apache.hadoop.hbase.snapshot.CorruptedSnapshotException: Couldn't read
> snapshot info from:/tmp
> /hbase-huser/hbase/.hbase-snapshot/goods_v3_hbase_snap0/.snapshotinfo
>
>         at
> org.apache.hadoop.hive.hbase.HBaseStorageHandler.configureTableJobProperties(HBaseStorageHandler.java:401)
>
>         at
> org.apache.hadoop.hive.hbase.HBaseStorageHandler.configureInputJobProperties(HBaseStorageHandler.java:317)
>
>         at
> org.apache.hadoop.hive.ql.plan.PlanUtils.configureJobPropertiesForStorageHandler(PlanUtils.java:809)
>
>         at
> org.apache.hadoop.hive.ql.plan.PlanUtils.configureInputJobPropertiesForStorageHandler(PlanUtils.java:779)
>
>         at
> org.apache.hadoop.hive.ql.optimizer.SimpleFetchOptimizer$FetchData.convertToWork(SimpleFetchOptimizer.java:379)
>
>         at
> org.apache.hadoop.hive.ql.optimizer.SimpleFetchOptimizer$FetchData.access$000(SimpleFetchOptimizer.java:319)
>
>         at
> org.apache.hadoop.hive.ql.optimizer.SimpleFetchOptimizer.optimize(SimpleFetchOptimizer.java:135)
>
>         at
> org.apache.hadoop.hive.ql.optimizer.SimpleFetchOptimizer.transform(SimpleFetchOptimizer.java:106)
>
>         ... 22 more
>
> Caused by: org.apache.hadoop.hbase.snapshot.CorruptedSnapshotException:
> Couldn't read snapshot info from:/tmp
> /hbase-huser/hbase/.hbase-snapshot/goods_v3_hbase_snap0/.snapshotinfo
>
>         at
> org.apache.hadoop.hbase.snapshot.SnapshotDescriptionUtils.readSnapshotInfo(SnapshotDescriptionUtils.java:307)
>
>         at
> org.apache.hadoop.hbase.snapshot.RestoreSnapshotHelper.copySnapshotForScanner(RestoreSnapshotHelper.java:727)
>
>         at
> org.apache.hadoop.hbase.mapreduce.TableSnapshotInputFormatImpl.setInput(TableSnapshotInputFormatImpl.java:364)
>
>         at
> org.apache.hadoop.hive.hbase.HBaseTableSnapshotInputFormatUtil.configureJob(HBaseTableSnapshotInputFormatUtil.java:77)
>
>         at
> org.apache.hadoop.hive.hbase.HBaseStorageHandler.configureTableJobProperties(HBaseStorageHandler.java:387)
>
>         ... 29 more
>



-- 
*  Regards*
*  Sandeep Nemuri*

Reply via email to