1.HBase hbase-site.xml 参数
2.Hbae数据库性能调优
3.HBase性能优化方法总结
4.【甘道夫】HBase基本数据操作详解【完整版,绝对精品】
5.Apache HBase ™ Reference Guide
以上5篇都很有帮助
1.配置优化:
1.zookeeper.session.timeout
默认值: 3min(180000ms)
说明: RegionServer与Zookeeper间的连接超时时间。当超时时间到后,ReigonServer会被Zookeeper从RS集群清单中移除,HMaster收到移除通知后,会对这台server负责的regions重新balance,让其他存活的RegionServer接管.
调优:
这个timeout决定了RegionServer是否能够及时的failover。设置成1分钟或更低,可以减少因等待超时而被延长的failover时间。
不过需要注意的是,对于一些Online应用,RegionServer从宕机到恢复时间本身就很短的(网络闪断,crash等故障,运维可快速介入),如果调低timeout时间,反而会得不偿失。因为当ReigonServer被正式从RS集群中移除时,HMaster就开始做balance了 (让其他RS根据故障机器记录的WAL日志进行恢复)。当故障的RS在人工介入恢复后,这个balance动作是毫无意义的,反而会使负载不均匀,给RS 带来更多负担。特别是那些固定分配regions的场景。
2. hbase.regionserver.handler.count
默认值: 10
说明: RegionServer的请求处理IO线程数。
调优:
这个参数的调优与内存息息相关。
较少的IO线程,适用于处理单次请求内存消耗较高的Big PUT场景(大容量单词PUT或设置了较大cache的scan,均属于Big PUT)或RegionServer的内存比较紧张的场景。
较多的IO线程,适用于单词请求内存消耗低,TPS要求非常高的场景。设置该值的时候,以监控