root和meta表
在版本0.9.8之前,存在root表,之后的版本中去除了root表,meta表主要记录了每个表在region的分布情况。
meta结构
从表格中可以看出,rowkey格式:tablename,startkey,timeStamp,meta表主要的列簇为info,其中info:regioinfo列包含了region的主要信息,info:server包含了改region所在的地址和端口
当meta表过大时(不知道没有root表之后,meta表过大如何处理),meta表也分了region,存储在了不同的regionserver中,这是使用root表检索meta表
client连接hbase经历三次连接,
- client连接zookeeper,获取存储root表的regionserver地址信息
- client连接具体的regionserver,从root表中获取meta表的regionserver的地址信息
- client连接具体的regionserver,获取具体数据的regionserver的地址信息
- client连接到regionserver,操作数据
在整一个连接流程中不会涉及到连接hmaster,所以不会对hmaster造成压力