gpt4 book ai didi

docker - 在 Docker Swarm 中使用 “bind” 卷挂载和 docker-compose 文件

转载 作者:行者123 更新时间:2023-12-02 18:29:28 45 4
gpt4 key购买 nike

我的环境使用的是 3 节点 Docker Swarm(都是管理器),我有一个 docker-compose.yaml,它被创建用于部署到 Swarm。

在我的 docker-compose.yaml 中,我设置了两个服务,一个是 MySQL 实例,另一个是我的自定义 Django 应用程序。

我想做的是两方面的:

  • 我需要将本地目录(例如:/test)挂载到容器中。该文件确实存在于主机/节点/服务器上,我正在尝试将其挂载到容器中存在的文件(例如:/tmp)。
  • 创建一个持久性数据库文件夹,以便我们的 MySQL 在容器退出时不会被破坏。

  • 我的问题是我无法在容器内显示本地主机文件(在这种情况下为/test)。我尝试使用长语法和短语法来创建“绑定(bind)挂载”。

    这是我的 docker-compose.yaml 文件:
    version: '3.2'
    services:
    project_mysql:
    environment:
    MYSQL_USER: 'project'
    MYSQL_PASSWORD: 'password1234'
    ports:
    - 3306:3306
    image: 'mysql/mysql-server'
    tty: true
    stdin_open: true
    deploy:
    mode: replicated
    replicas: 1
    restart_policy:
    condition: on-failure
    placement:
    constraints:
    - node.hostname == node1
    healthcheck:
    test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost"]
    interval: "5s"
    timeout: "1s"

    project_web:
    image: 'localhost:5123/project_web:0.1.5'
    tty: true
    stdin_open: true
    volumes:
    - type: bind
    source: /test
    target: /tmp
    ports:
    - 8000:8000
    depends_on:
    - project_mysql
    healthcheck:
    test: ["CMD-SHELL", "nc -z 127.0.0.1 8000 || exit 1"]
    interval: "5s"
    timeout: "1s"

    networks:
    projectnet:
    driver: overlay
    ipam:
    config:
    - subnet: 10.2.0.0/24

    感谢您的帮助!

    最佳答案

    您需要将命名卷添加到 docker-compose.yaml 文件中。

    在启动实例之前,运行 docker volume create mysql-data然后,在 docker-compose.yaml添加:

    services:
    project_mysql:
    volumes:
    - mysql-data:/var/lib/mysql

    volumes:
    mysql-data:
    external: true

    如果您终止该服务,数据仍将保留。

    关于docker - 在 Docker Swarm 中使用 “bind” 卷挂载和 docker-compose 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51642342/

    45 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com