现在有一个在 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 友。
1
lovepocky 2019-03-02 10:50:52 +08:00 via iPhone 1
给一条思路,docker 网络里面再开一个 socks 代理端口,然后 client 走代理进去。
另外,要求不高的开发的话,我自己倾向于 client 也在 docker 里面,不清楚 lz 不方便是指哪些方面。 |