HBase里表的create/disable/enable/drop 过程

一、相关背景

      在HBase里、类似于传统关系型数据库的DDL操作的RPC请求差不多都是由HBase里面的HMaster执行的。当RPC请求发送到HMaster所在的节点之后,由MasterRpcServices调用HMaster里面对应的方法进行处理。


相关RPC请求在Server端的处理类图


      在HMaster中,通过调用ExecutorService里面的submit方法,将相关处理线程(EventHandler)提交给线程池处理。其中处理创建表的线程就是上面的CreateTableHandler。上面的prepare方法主要可以用于一些基本的检测,而process方法则是处理相关逻辑的方法。

二、create过程

      create的过程主要是process方法通过调用handleCreateTable来实现,具体过程代码中也有非常详细的注释。主要就是创建相关的目录结构,然后更新hbase:meta表里面的相关信息,接着随机分配预定义的分区(当然要创建者指定了相关的分区),还有添加相关副本以及zookeeper里面的信息,最后还要更新HMaster里面的相关表缓存。

三、disable过程

      disable过程主要是通过DisableTableHandler来完成的,比如这里面的prepare过程就会检查要disable的不是hbase:meta表。而disable过程主要是通过handleDisableTable来完成的,在hbase.bulk.assignment.waiton.empty.rit(默认五分钟)内,必须通过HMaster的assignmentManager来负责将所有的region进行批量unassign操作,否则就超时了。当然还需要更新zookeeper里面的信息。

四、enable过程

      enable过程主要是通过EnableTableHandler类来完成。首先要获取相对应的region信息,如果是meta表,则直接通过构造方法来构造相应的locator(八成是启动时要enable meta表吧,以后再再细看);如果是别的表则通过meta表来获取相应的位置信息。还会考虑replica相关的东西(这个以后有机会再单独介绍),最后根据所有的regionserver执行批量分配所有的region。当然整个过程也会涉及zookeeper信息的更新。这个批量分配过程也是按照hbase.bulk.assignment.waiton.empty.rit为超时时间的。也可以根据hbase.bulk.assignment.threadpool.size来控制批量分配的线程数(默认20个)。

五、drop过程

      drop过程主要通过DeleteTableHandler类来完成。drop以及增加列族这类操作比较特别、比如需要上锁等等,因此所有相关handler都继承自TableEventHandler,并在父类中通过masterService进行上锁操作。在具体的处理逻辑中,首先会考虑到region可能正在处于transition过程,所以需要等待一段时间(超过hbase.master.wait.on.region则视为超时),接着删除hbase:meta以及HDFS中的数据,然后就是删除一些缓存信息,例如HMaster中关于表的缓存、region缓存,最后还会调用cleanAnyRemainingRows();方法确认hbase:meta表里面的所有信息完全删除。当然有上锁操作就会有解锁操作,父类TableEventHandler的finally块中会release相关的锁。

六、总结

      以上博客都是关于HBase社区1.0.0版的个人总结,如有不足之处欢迎指正。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容

  • 初次接触HBase的读者,建议先阅读浅析HBase:为高效的可扩展大规模分布式系统而生 HBase的构成 物理上来...
    耀凯考前突击大师阅读 5,245评论 0 12
  • 最近在逐步跟进Hbase的相关工作,由于之前对Hbase并不怎么了解,因此系统地学习了下Hbase,为了加深对Hb...
    飞鸿无痕阅读 50,209评论 19 272
  • HBase那些事 @(大数据工程学院)[HBase, Hadoop, 优化, HadoopChen, hbase]...
    分痴阅读 3,935评论 3 17
  • 1. HBase介绍,Hbase是什么? HBase -- Hadoop Database ,是一个高可靠、高性能...
    奉先阅读 3,732评论 1 36
  • HBase存储架构图 HBase Master 为Region server分配region 负责Region s...
    kimibob阅读 5,572评论 0 52