使用 docker 搭建分布式数据库的问题

2019-03-01 14:48:12 +08:00
 cbwleft

现在有一个在 docker 内运行的分布式数据库,每个节点都运行在单独的 docker 内,通过 bridge 网络连接,master 作为注册中心,slave 将自身的 hostname 和 port 注册在 master 上。client 连接 master 时,master 会返回 slave 的 hostname 和 port。client 再通过 slave 的 hostname 进行 RPC 连接读取数据。很多基于 hdfs 的分布式数据库都是这样的架构。

现在问题是,client 是在宿主机运行的,而 slave 是在 docker 中运行的,client 无法解析 docker 的 hostname。

自己想的几种可行的方案:

总感觉 docker 有更加优雅的解决方案,在此请教各位渊博的 V 友。

3243 次点击
所在节点    Docker
2 条回复
lovepocky
2019-03-02 10:50:52 +08:00
给一条思路,docker 网络里面再开一个 socks 代理端口,然后 client 走代理进去。
另外,要求不高的开发的话,我自己倾向于 client 也在 docker 里面,不清楚 lz 不方便是指哪些方面。
cbwleft
2019-03-04 10:35:19 +08:00
@lovepocky 因为 client 一般是一个 jar 包,不方便把 Java 开发环境丢到 docker 里面

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/540030

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX