Docker-Compose 持久数据 MySQL

新手上路,请多包涵

如果我运行 $ docker-compose down 和以下 .yml ,我似乎无法让 MySQL 数据保持不变

version: '2'
services:
  # other services

  data:
    container_name: flask_data
    image: mysql:latest
    volumes:
      - /var/lib/mysql
    command: "true"

  mysql:
    container_name: flask_mysql
    restart: always
    image: mysql:latest
    environment:
      MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
      MYSQL_USER: 'test'
      MYSQL_PASS: 'pass'
    volumes_from:
      - data
    ports:
      - "3306:3306"

我的理解是,在我的 data 容器中使用 volumes: - /var/lib/mysql 将其映射到我的本地机器目录,mysql 将数据存储到容器中,并且由于这种映射,即使容器是被摧毁。而 mysql 容器只是进入数据库的客户端接口,可以看到本地目录,因为 volumes_from: - data

尝试了这个答案,但没有奏效。 Docker-Compose 持久数据问题

编辑

Changed my .yml as shown below and created a the dir ./data but now when I run docker-compose up --build the mysql container wont start throws error saying

   data:
    container_name: flask_data
    image: mysql:latest
    volumes:
      - ./data:/var/lib/mysql
    command: "true"

  mysql:
    container_name: flask_mysql
    restart: always
    image: mysql:latest
    environment:
      MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
      MYSQL_USER: 'test'
      MYSQL_PASS: 'pass'
    volumes_from:
      - data
    ports:
      - "3306:3306"

flask_mysql | mysqld: Can't create/write to file '/var/lib/mysql/is_writable' (Errcode: 13 - Permission denied)
flask_mysql | 2016-08-26T22:29:21.182144Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
flask_mysql | 2016-08-26T22:29:21.185392Z 0 [ERROR] --initialize specified but the data directory exists and is not writable. Aborting.

原文由 Adam 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 768
2 个回答

数据容器是一种多余的解决方法。 数据量 会为您解决问题。将您的 docker-compose.yml 更改为:

 version: '2'
services:
  mysql:
    container_name: flask_mysql
    restart: always
    image: mysql:latest
    environment:
      MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
      MYSQL_USER: 'test'
      MYSQL_PASS: 'pass'
    volumes:
      - my-datavolume:/var/lib/mysql
volumes:
  my-datavolume:

Docker 将在 /var/lib/docker/volumes 文件夹中为您创建卷。只要您不输入 docker-compose down -v

原文由 Ohmen 发布,翻译遵循 CC BY-SA 3.0 许可协议

有3种方式:

第一种方式

您需要指定在 主机 上存储 mysql 数据的目录。然后,您可以删除数据容器。您的 mysql 数据将保存在您的本地文件系统上。

Mysql 容器定义必须如下所示:

 mysql:
  container_name: flask_mysql
  restart: always
  image: mysql:latest
  environment:
    MYSQL_ROOT_PASSWORD: 'test_pass' # TODO: Change this
    MYSQL_USER: 'test'
    MYSQL_PASS: 'pass'
volumes:
 - /opt/mysql_data:/var/lib/mysql
ports:
  - "3306:3306"

第二种方式

在输入 docker-compose down 之前提交数据容器:

 docker commit my_data_container
docker-compose down

第三种方式

你也可以使用 docker-compose stop 而不是 docker-compose down (那么你不需要提交容器)

原文由 Bukharov Sergey 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题