当前位置: 首页 > 知识库问答 >
问题:

Docker-编写持久数据MySQL

能烨华
2023-03-14

如果使用以下.yml运行$docker-compose down,似乎无法持久保存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将数据存储到容器的本地machines目录,由于这种映射,即使容器被破坏,数据也应该保持不变。而MySQL容器只是db的客户端接口,可以看到本地目录,这是因为volumes_from:-data

尝试了这个答案,但没有成功。Docker-编写持久数据故障

编辑

如下所示更改了我的.yml,并创建了一个dir./data,但现在当我运行docker-compose up-build时,mysql容器不会启动,会抛出一个错误:

  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.

共有1个答案

商飞航
2023-03-14

数据容器是一种多余的变通方法。数据量可以帮你解决问题。将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,此卷就会继续存在

 类似资料:
  • 问题内容: 如果使用以下命令运行,我似乎无法使MySQL数据持久化 我的理解是,在我的容器中,使用将其映射到我的本地计算机目录,在该目录中mysql将数据存储到容器中,由于这种映射,即使容器被破坏,数据也应持久存在。而且容器只是进入db的客户端接口,可以看到本地目录,因为 编辑 改变了我如下图所示,并创造了该目录,但现在当我运行的容器不会开始抛出错误说 问题答案: 数据容器是一个多余的解决方法。数

  • 我在我的项目中使用postgres docker映像。对于初始化,我使用以下命令来创建和初始化我的数据库(表、视图、数据…) 复制sql_dump.sql /docker-entrypoint-initdb.d 容器停止和删除后是否可以保留这些数据?例如,当我运行postgres的图像时,它将使用这些数据创建数据库,而每次容器启动时都没有加载脚本。只需加载第一次运行创建的数据。 我做了一些研究,发

  • 问题内容: 我正在尝试编写一个持久/缓存脚本。代码看起来像这样: 可以从Shell脚本在循环中调用,如下所示 有没有办法我可以以保持状态的方式调用此脚本。从一个电话到另一个电话。假设初始化’%my_hash’和调用extract_values_from_file都是一项昂贵的操作。 谢谢 问题答案: 如果示例中的%my_hash在其最终初始化状态下具有中等大小,则可以简单地使用序列化模块之一,例如

  • 在docker compose v3容器关闭并重新启动后,我很难持久化postgres数据。这似乎是一个常见的问题,但经过大量搜索,我一直无法找到有效的解决方案。 我的问题与此类似:如何使用卷在dockerized postgres数据库中持久化数据,但解决方案不起作用-因此请不要关闭。我将通过下面的所有步骤来复制这个问题。 这是我的docker-compose文件: 这是我调出并写入数据库后的终

  • 我刚开始使用docker,但我不明白一些事情。我只是使用docker-compose来使用PostgreSQL的基本映像,但我不知道如何在杀死docker甚至删除我的本地映像后使db中的数据持久化。这一切都可能吗? 这是我实际的docker-compose.yml: 也许我应该用体积?怎样