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

标签 docker docker-compose docker-swarm docker-volume

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

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

我想做的有两个:

  1. 我需要将本地目录(例如:/test)挂载到容器中。该文件确实存在于主机/节点/服务器上,我正在尝试将其安装到容器中存在的文件(例如:/tmp)。
  2. 创建一个持久数据库文件夹,以便我们的 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/

相关文章:

neo4j - 无法在 Docker Swarm 中发现其他 Neo4J 因果集群实例

mysql docker 容器未启动,mysqld : Can't create/write to file '/var/lib/mysql/is_writable' (OS errno 13 - Permission denied)

Docker:如何控制/定义默认网关设置

docker - 我需要在集群模式下的所有节点中安装 docker 吗?

linux - Docker:压缩文件但排除某些文件夹

python - 在 Docker 中的 Ubuntu 上使用 azure.storage.blob.BlockBlobService 运行 python 脚本时没有名为 '_cffi_backend' 的模块

java - 如何在 Alpine docker 容器上使用 openjdk 14 启用 ECDHE 密码?

docker - GCP中的Cloud Run服务显示 “Container failed to start and then listen on the port defined by the PORT environment variable” Codeigniter 4

docker-compose:使用相同的 container_name 在多个项目之间共享容器

docker - 在运行时设置 docker-compose.yml 的端口