it-swarm.asia

Docker-撰写持久数据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持久性数据问题

_编辑_

改变了我的.yml,如下所示并创建了一个dir ./data但是现在当我运行docker-compose up --buildmysql容器不会开始抛出错误说

  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.
96
Adam

数据容器是一个多余的解决方法。 数据量 可以帮到你。将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,此卷就会一直存在

142
Ohmen

有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(那时你不需要提交容器)

32
Bukharov Sergey

您必须为mysql数据创建单独的卷。

所以它看起来像这样:

volumes_from:
  - data
volumes:
  - ./mysql-data:/var/lib/mysql

不,/var/lib/mysql是mysql容器中的路径,与主机上的路径无关。您的主机甚至可能根本没有mysql。因此,目标是从mysql容器中持久保存内部文件夹。

9
Dmitry Malyshenko

实际上这是路径,你应该提到一个有效的路径来工作。如果你的数据目录在当前目录中,那么你应该提到my-data而不是./my-data,否则它也会在mysqlmariadb中给你这个错误。

volumes:
 ./my-data:/var/lib/mysql
1
codelearner