基于docker搭建开发环境省去了许多配置工作,能够提高效率,但也带来了一些和网络相关的坑,特此记录:
端口是否全部映射?
hbase使用的端口非常多,zookeeper/region server/master server...,如果遗漏了端口未映射到本地端口,本地java client访问将报错
region server名称是否在本地路由表中映射?
本地使用docker启动后,可以通过web页面查看详情:

注意到此处的region server使用的名称并非ip而是一串随机id(实际上是docker container的id),因此需要在/etc/hosts文件中增加本地127.0.0.1到此id的映射,增加后通过ping指令确认是否成功,成功后即可本地访问。
如果未修改,将出现如下的错误:
org.apache.hadoop.hbase.ipc.AbstractRpcClient - Not trying to connect to......
特此记录。
补充自己使用的docker image: harisekhon/hbase。
1924

被折叠的 条评论
为什么被折叠?



