docker-compose links用法--docker之间如何访问

version: "3"
services:
  backend:
    build:
      context: backend
      dockerfile: Dockerfile-backend
    ports:
      - "8099:8099"
      - "8009:8009"
    links:
      - mongo
    depends_on:
      - mongo
  mongo:
    build:
      context: mongo
      dockerfile: Dockerfile-mongo
    volumes:
      - xtest-data:/data/db
    expose:
      - "27017"
    # uncommand to able host visit mongo
    #ports:
    # - "27017:27017"
    command: ./start_mongo.sh
volumes:
  xtest-data:

如上内容,其他容器使用links可以将mongo容器的ip记录到该容器中, 再通过连接 mongo:27017 可以访问数据库。
通过depends_on来标记依赖关系, 当mongo服务启动完成后, 才会启动backend服务;

由于后端代码只考虑到mongodb与后端服务部署在同一台宿主机情况下, mongo的host始终为127.0.0.1, 因此需要修改后端代码, 判断为容器时host=mongo, 不为容器时host=127.0.0.1.

在Python代码中判断当前环境是否为容器的方法可以参考文章:https://www.jianshu.com/p/f7bc8f3be2d8

 

Docker ComposeDocker 官方提供的一个工具,用于定义和运行多个 Docker 容器的集合,通常用于微服务架构中的服务编排。如果你想使用 Docker Compose 来编排 Kafka(一个分布式消息队列系统),你可以创建一个 `docker-compose.yml` 文件,该文件会定义 Kafka 服务、Zookeeper(Kafka 需要 Zookeeper 协作)以及任何依赖关系。 以下是一个简单的 `docker-compose.yml` 示例,假设你想要部署一个单节点的 Kafka 集群: ```yaml version: '3' services: zookeeper: image: confluentinc/cp-zookeeper:latest environment: ZOOKEEPER_SERVER_ID: 1 ZOOKEEPER_CLIENT_PORT: 2181 kafka: image: confluentinc/cp- zookeeper environment: KAFKA_BROKER_ID: 1 KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181 KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:9092 KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1 # 如果有其他依赖于 Kafka 的应用,比如生产者或消费者 producer: image: your-producer-image depends_on: - kafka environment: KAFKA_BOOTSTRAP_SERVERS: kafka:9092 consumer: image: your-consumer-image depends_on: - kafka environment: KAFKA_BOOTSTRAP_SERVERS: kafka:9092 # 如果需要配置更复杂的网络,可以添加 network 或 links 部分 ``` 在这个例子中: - `zookeeper` 服务负责维护集群的状态。 - `kafka` 服务是消息队列的实际实例,连接到 Zookeeper 并监听 9092 端口。 - `producer` 和 `consumer` 代表生产者和消费者应用,它们依赖于 Kafka 并设置适当的环境变量来连接到 Kafka 服务器。 执行 `docker-compose up` 命令后,所有服务将被自动拉取镜像并启动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值