当前位置:  开发笔记 > 数据库 > 正文

连接两个docker-compose实例

如何解决《连接两个docker-compose实例》经验,为你挑选了1个好方法。

我有一个dockerized应用程序,其中一些服务使用docker-compose运行.我想使用另一个搬运工-撰写应用,来连接与ElasticSearch/Logstash/Kibana(ELK)本申请搬运工-麋鹿.它们都在开发中的同一个docker机器上运行.在生产中,情况可能并非如此.

如何配置我的应用程序docker-compose.yml以链接到ELK堆栈?



1> Bernard..:

2016年6月更新

以下答案从docker 1.10开始已过时.请参阅此解决方案的其他类似答案. /sf/ask/17360801/

老答案

    创建一个网络:

     $ docker network create --driver bridge my-net
    

    将网络引用为${NETWORK}docker-compose.yml文件中的环境变量().例如:

    pg:
      image: postgres:9.4.4
      container_name: pg
      net: ${NETWORK}
      ports:
        - "5432"
    myapp:
      image: quay.io/myco/myapp
      container_name: myapp
      environment:
        DATABASE_URL: "http://pg:5432"
      net: ${NETWORK}
      ports:
        - "3000:3000"
    

请注意,pgin http://pg:5432将解析为pg服务(容器)的ip地址.无需硬编码IP地址; pg的条目会自动添加到myapp容器的/ etc/host中.

    调用docker-compose,将其传递给您创建的网络:

    $ NETWORK=my-net docker-compose up -d -f docker-compose.yml -f other-compose.yml
    

我创建了一个桥接网络,只能在一个节点(主机)内工作.对开发者有好处.如果需要让两个节点相互通信,则需要创建一个覆盖网络.同样的原则.您将网络名称传递给docker-compose up命令.

推荐阅读
小妖694_807
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有