现在有一个在 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。
自己想的几种可行的方案:
- 完全使用 host 网络,但是会产生端口冲突
- slave 注册自身的 172 开头 ip 地址,这样宿主机可以访问了,但是无法跨主机通讯
- 把 client 也丢到 docker 里面,但是这样不方便进行开发测试
总感觉 docker 有更加优雅的解决方案,在此请教各位渊博的 V 友。
