正文
修改hbase表,修改hbase表名
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
hbase多张表自动切换
1、hbase不支持多表连接。HBase没有太多复杂的多表连接,只有简单的插入、查询、删除、更新等。对于数据操作,HBase没有多表连接操作。对于存储模式,HBase基于列,关系数据库基于行。数据维护方面,HBase没有数据覆盖的操作。
2、默认,HBase 在创建表的时候,会自动为表分配一个 Region,正处于混沌时期,start-end key 无边界,所有 RowKey 都往这个 Region里分配。
3、执行完命令后,验证hbase是否启动正常,可以在浏览器中输入:http://1916188:60010/master.jsp 出现以下页面可表示hbase安装配置成功。
4、这是一个工具类,将map输出的value(只能是Put或Delete)pass给HBase。
HBase调优:预分区与行键设计
1、像这样预先创建hbase表分区的方式,称之为预分区。hash(主键) + 年月日时(2019062315)这里只取hash(主键)的前6位,使得行键的长度正好是16,也就是8的整数倍,在64位计算机中,效果最好。
2、像这样预先创建hbase表分区的方式,称之为预分区。hash(主键)+年月日时(2019062315)这里只取hash(主键)的前6位,使得行键的长度正好是16,也就是8的整数倍,在64位计算机中,效果最好。
3、已经有自动分区了,为什么还需要预分区? HBase 在创建表的时候,会自动为表分配一个Region,当一个 Region 达到拆分条件时(shouldSplit 为 true),HBase 中该 Region 将会进行 split,分裂为2个 Region,以此类推。
4、优化建议:检查RowKey设计以及预分区策略,保证写入请求均衡。 KeyValue大小对写入性能的影响巨大,一旦遇到写入性能比较差的情况,需要考虑是否由于写入KeyValue数据太大导致。
5、目前我们已经确定了hbase存储,并且采用预分区的方式并且采用rowkey进行过滤查询,那么现在考虑rowkey的设计。
hbase预分区表能调整吗
默认情况下,在创建HBase表的时候会自动创建一个region分区,当导入数据的时候,所有的HBase客户端都向这一个region写数据,直到这个region足够大了才进行切分。
自然split的几率也会大大降低。当然随着数据量的不断增长,该split的还是要进行split。像这样预先创建hbase表分区的方式,称之为预分区。
预分区后,可以从 HBase ui 页面观察到: HBase API 建预分区表 为防止热点问题,同时避免 Region Split 后,部分 Region 不再写数据或者很少写数据。
hbase.hregion.max.filesize 设定的region大小,超过了就会split,就会增加一个region,对预分区没什么影响。
hbase.hstore.blockingStoreFiles默认设置为7,可以适当调大一些。
- Region Server 上运行的 Region 总数 Region 越多,Region Server 上维护的 MemStore 就越多。根据业务表读写请求量和 RegionServer 可分配内存大小,合理设置表的分区数量(预分区的情况)。
修改hbase表的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于修改hbase表名、修改hbase表的信息别忘了在本站进行查找喔。