查看HFile命令
命令: hbase hfile -v -p -m -f +要查看文件的路径
hbase hfile -v -p -m -f hdfs://ns/hbase/data/default/TEST1/5cd31c374a3b30bb859175495cbd6905/df/9df89dc0db7f401e943c5ded6d49d956
HFile放在哪里了?
查看方式一
可以通过HBase的web页面查看HFile名称及路径。步骤如下:
① 打开Web管理页面,选择表 data:image/s3,"s3://crabby-images/26b77/26b770212dae0bda06ec6641bc160d6cc327fe14" alt="在这里插入图片描述" ② 选择HRegion Server data:image/s3,"s3://crabby-images/57a01/57a0163284afbbe0f1261c7b2136999f358ea3ff" alt="在这里插入图片描述" ③ 选择Region data:image/s3,"s3://crabby-images/44eb1/44eb104bbb0f32933cc45dce40c248c3eaef7fc0" alt="在这里插入图片描述" ④ 查看HFile路径
HFile是以列族为单位的,我建立的表有两个列族,所以这里就有两个HFile data:image/s3,"s3://crabby-images/e2494/e24949c072604ba49d3b0ef2c2642196d2b401e7" alt="在这里插入图片描述"
查看方式二
1.直接使用hdfs命令,逐层查看
命令样例:hadoop fs -ls /hbase/data/default data:image/s3,"s3://crabby-images/7b001/7b00180abe13ded876530c545ba51f178493677e" alt="在这里插入图片描述" 2. 为什么能scan到数据,却没有hfile? 通过程序向HBase插入数据之后,能够scan到数据,不过hdfs上确没有hfile。
如下图所示:scan ‘TEST1’ 能够看到表中有数据。 data:image/s3,"s3://crabby-images/9d07c/9d07c8ea404f28fbbc720b36c7cdb7181d7dccb2" alt="在这里插入图片描述" 从Web页面上却看不到hfile data:image/s3,"s3://crabby-images/758fa/758fa281918e479a1dc597c698154a543900eb0d" alt="在这里插入图片描述" 原因:
插入的数据在memstore(写缓存)中,还没有flush到hdfs上。
解决办法:
手动flush。在hbase shell环境下,有一个flush命令,可以手动刷某张表 data:image/s3,"s3://crabby-images/3bd45/3bd45fa785c4defb8046fdafeb8c966302caaaa9" alt="在这里插入图片描述" flush之后,就可以看到hfile了 data:image/s3,"s3://crabby-images/3e2c2/3e2c2d4ebab060ad605ac639e283eb5848357cec" alt="在这里插入图片描述" 查看HFile 命令:
hbase hfile -v -p -m -f hdfs://ns/hbase/data/default/TEST1/5cd31c374a3b30bb859175495cbd6905/df/9df89dc0db7f401e943c5ded6d49d956
|