当前位置: 首页 > 面试题库 >

Docker-组合持久数据MySQL

鲁淇
2023-03-14
问题内容

如果$ docker-compose down使用以下命令运行,我似乎无法使MySQL数据持久化.yml

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容器只是进入db的客户端接口,可以看到本地目录,因为volumes_from:- data

编辑

改变了我.yml如下图所示,并创造了该目录./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.

问题答案:

数据容器是一个多余的解决方法。数据量将为您解决问题。将您更改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-composedown -v



 类似资料:
  • 如果使用以下运行,似乎无法持久保存MySQL数据 我的理解是,在我的容器中,使用将其映射到mysql将数据存储到容器的本地machines目录,由于这种映射,即使容器被破坏,数据也应该保持不变。而容器只是db的客户端接口,可以看到本地目录,这是因为 尝试了这个答案,但没有成功。Docker-编写持久数据故障 编辑 如下所示更改了我的,并创建了一个dir,但现在当我运行时,容器不会启动,会抛出一个错

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

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

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

  • 并了解了如何制作仅数据容器:http://container42.com/2014/11/18/data-only-container-madness/ 我也看到了与我类似的问题:如何在docker中处理持久存储(例如数据库 但如果我有一个灯服务器设置..我用数据容器进行了一切很好的设置,而不是将它们“直接”链接到我的源操作系统,偶尔做一次备份… 总比有人过来重新启动我的服务器..我如何重新设置我