首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Docker-compose + MariaDB +4 4GB文件=极慢的数据库导入

Docker-compose + MariaDB +4 4GB文件=极慢的数据库导入
EN

Stack Overflow用户
提问于 2018-07-24 20:37:02
回答 1查看 397关注 0票数 2

我们有以下MySQL节点:

代码语言:javascript
复制
mysql:
    build: ./docker/builds/mysql
    ports:
      - "3306:3306"
    environment:
      - MYSQL_USER=root
      - MYSQL_PASSWORD=password
      - MYSQL_ROOT_PASSWORD=password
      - MYSQL_DATABASE=password
    volumes:
      - ./docker/data/ps_de:/data
      - ./docker/builds/mysql/my.cnf:/etc/mysql/my.cnf
      - ./docker/mysql:/var/lib/mysql_shared
    networks:
      vpcbr:
        ipv4_address: 172.55.0.20

这基本上就是用FROM mariadb:latest拉取MariaDB。

如果我们试图将巨大的SQL转储导入到这个数据库中,则需要花费大量的时间来完成此任务。

转储本身使用优化的设置进行转储,因此已经比普通转储“更快”。

在HDD上,导入4 4GB转储最多需要5个小时,而在SSD上,仍然需要55分钟。我读到过在使用Docker时将如此庞大的数据导入MySQL时出现的问题。

其他人也有这个问题吗?你是如何解决它的?

EN

回答 1

Stack Overflow用户

发布于 2019-10-21 21:32:50

Docker中的数据导入基本上是一个标准化的过程。

导入速度取决于您的SSD/HDD和您要导入的转储文件的大小。根据硬盘的IO速度,导入可能需要一些时间。

我们花了几个小时来实现一个进度条,但公平地说,这不值得花时间,因为速度也不会随着它而增加。

我们在导入50+GB转储时所做的是从物理DB文件(直接存储在MariaDB/MySQL中)生成转储,而不是导入转储。下载一个50 is的包比导入一个50 is的转储要快得多。

这不是最好的方法,因为你不能在这里应用Dev-Settings ( Docker的入口点可以),而且你可能需要一个来自你的公司的SRE/DevOps来提供转储本身,但值得一试。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51498819

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档