【hbase】kubernets上部署hbase注意

1. hbase架构

hbase 架构.png

hbase架构如上,从部署维度考虑,其架构特性如下:

  • 计算(hbase)、存储(hdfs)分离,且均为高可用架构
  • 自动服务发现机制
  • 链路长,关联组件多
  • 平行拓展,性能要求高

2. hbase 组件

  • zookeeper:zk负责hbase服务注册发现,以及hbase master管理数据存放,有独立的存储盘
  • hbase:核心功能组件,分为master 和 regionserver
    • master: 控制中心,主要负责数据调度管控,及regionserver的分区管理,可以多副本,主备关系,无选举
    • regionserver:存储管理节点,支持数据读写,多副本,多副本共同形成类似于RAID-0存储结构,但因分区信息由master存放在zk上做管理,所以挂掉部分也对业务影响不大,不会导致整套服务无法读写
  • hadoop:作为存储池,提供hdfs分布式存储能力,分为namenode 和 datanode
    • namenode:
    • datanode:

3. helm部署

3.1 部署

#chart包位置:https://artifacthub.io/packages/helm/gradiant/hbase
helm repo add gradiant https://gradiant.github.io/charts/
#部署hbase 的chart包版本0.1.6,对应hbase版本(2.0.1),zk(3.6.2),hadoop(2.7.7)
helm install my-hbase gradiant/hbase --version 0.1.6

3.2 版本定制

若上述hbase版本不符合使用需求,可以将上述chart包拉取到本地,定制参考:https://blog.csdn.net/weixin_34281537/article/details/89621989

4. 趟坑

4.1 snappy压缩算法不支持

描述: 因上述hbase底层存储用的hadoop(2.7.7)版本偏低,默认不支持snappy(hadoop2.8之后默认支持),业务方使用会产生很多失败region,并且RIT会很高,通过hbase hbck会有不一致问题
解决:定制(hadoop、hbase)镜像,具体如下:

  1. 制作hadoop镜像:将hadoop镜像拉到本地,定制Dockerfile,在hadoop镜像中安装snappy的库,并将snappy库及其软链放到/opt/hadoop-2.7.7/lib/native/目录下,制作镜像,并上传到私有仓库
  2. 制作hbase镜像:将hbase镜像拉到本地,定制Dockerfile,在hadoop镜像中安装snappy的库,并将上述/opt/hadoop-2.7.7/lib/native/目录下的库复制一份,放到/opt/hbase/lib/native/Linux-amd64-64下,若该目录不存在,则创建
  3. 制作hbase镜像:找到与上面安装snappy库版本一致的jar包(地址:https://mvnrepository.com/artifact/org.xerial.snappy/snappy-java)并下载,然后将该jar包放在/opt/hbase/lib/目录下,制作镜像,并上传到私有仓库
  4. 制作chart包:将hbase的chart 包拉取到本地,修改依赖的hadoop chart中使用的镜像,修改hbase自己使用的镜像

4.2 regionserver host不一致

描述:hbase 依赖于hostname,regionserver配置了多个service,导致coredns对host命令解析出来的结果会有多条,默认安装时部署了一个headless service,因业务需求在集群外访问regionserver,要regionserver IP 固定,因网络组件还不支持固定IP,故对每个regionserver配置了一个service,导致每个regionserver可以被解析出几个不同的结果
解决:解决方式两种:

  1. pod固定IP:最佳方式,可以把headless删除,只单独对每个regionserver配置一个service(可能有同学会疑问,不固定IP也可以这么搞,可以,但解决不了问题,host解析出来的结果会带上pod IP,如果pod重建,不光IP会变,host结果也会变)
  2. 取舍:只配置一个service,不单独为每个regionserver配置service,解除hbase 一致性隐患,优先保持功能,使用体验降级

4.3 初始化失败

描述: zk地址、hdfs地址访问不通
解决: 因zk、hdfs的地址均是动态生成,变量配置转换不合理,在chart包部署时替换成相应组件service name可以解决

4.4 性能不够

描述: cpu、mem、pv、hbase Xms Xmx等涉及到性能的参数,部署时未作评估调优
解决:优化chart包,做成定制化,提前做好评估部署,以免部署完使用了一段时间后,出现问题再调整

4.5 hbase和hadoop依赖同样的native库路径

描述: hbase 启动需要加载hadoop及相关压缩算法库,和hadoop有部分同样的依赖,在cloudera-manager部署模式下,可能hbase和hadoop部署在一台机器下,依赖建一个软链接即可,但k8s部署下是两套不同的镜像,导致依赖找不到,启动失败或运行中报错
解决: 将cm模式下相互依赖的包、库等,在hbase、hadoop都创建对应路径,并存放同样的文件,如:hbase的目录/opt/hbase/lib/native/Linux-amd64-64/和 hadoop的目录/opt/hadoop-2.7.7/lib/native/,可以尽量存放同样的库文件及软链

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

推荐阅读更多精彩内容