首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 开源软件 >

hbase平添大文件

2012-07-02 
hbase添加大文件一直使用hbase作大容量存储,因为hbase易于存取。今天,在录入数据的时候,突然报出一个KeyVal

hbase添加大文件

一直使用hbase作大容量存储,因为hbase易于存取。

今天,在录入数据的时候,突然报出一个KeyValue size too large。很是奇怪。

后来发现,该数据特别大,经查源码

private void validatePut(final Put put) throws IllegalArgumentException{    if (put.isEmpty()) {      throw new IllegalArgumentException("No columns to insert");    }    if (maxKeyValueSize > 0) {      for (List<KeyValue> list : put.getFamilyMap().values()) {        for (KeyValue kv : list) {          if (kv.getLength() > maxKeyValueSize) {            throw new IllegalArgumentException("KeyValue size too large");          }        }      }    }  }

?说明当某一列的值大于该值的时候,将会抛出该异常,又查看maxKeyValueSize,发现它调用的是hbase配置里的hbase.client.keyvalue.maxsize,默认大小为10M,即 10485760 。将它改大即可。

但是,当我修改完以后,启动hbase总是出问题,后来又将hbase-env.sh里的HBASE_HEAPSIZE改大。

后来又将mapred-site.xml中的mapred.tasktracker.indexcache.mb改大,至于大于hbase.client.keyvalue.maxsize,不知道有没有影响,以防万一吧,我觉得hbase的执行应该是跟job有关系的吧。

请大家多多指教

?

热点排行