V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
cbwleft
V2EX  ›  Docker

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

  •  
  •   cbwleft · 2019-03-01 14:48:12 +08:00 · 3272 次点击
    这是一个创建于 2129 天前的主题,其中的信息可能已经有所发展或是发生改变。

    现在有一个在 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 友。

    2 条回复    2019-03-04 10:35:19 +08:00
    lovepocky
        1
    lovepocky  
       2019-03-02 10:50:52 +08:00 via iPhone   ❤️ 1
    给一条思路,docker 网络里面再开一个 socks 代理端口,然后 client 走代理进去。
    另外,要求不高的开发的话,我自己倾向于 client 也在 docker 里面,不清楚 lz 不方便是指哪些方面。
    cbwleft
        2
    cbwleft  
    OP
       2019-03-04 10:35:19 +08:00
    @lovepocky 因为 client 一般是一个 jar 包,不方便把 Java 开发环境丢到 docker 里面
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2352 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 00:18 · PVG 08:18 · LAX 16:18 · JFK 19:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.