如何解决--initialize指定但数据目录中包含文件。在laradock mysql容器上

时间:2018-04-22 12:04:24

标签: mysql laravel docker laradock

我正在使用laradock。 当我使用docker-compose up mysql时 我收到了这个错误。

mysql_1                | Initializing database
mysql_1                | 2018-04-22T10:41:01.362165Z 0 [ERROR] --initialize specified but the data directory has files in it. Aborting.
mysql_1                | 2018-04-22T10:41:01.362585Z 0 [ERROR] Aborting
mysql_1                |
laradock_mysql_1 exited with code 1

我尝试在laradock / mysql / Dockerfile上添加此设置,如此

ARG MYSQL_VERSION=latest
FROM mysql:${MYSQL_VERSION}

LABEL maintainer="Mahmoud Zalt <mahmoud@zalt.me>"

#####################################
# Set Timezone
#####################################

ARG TZ=UTC
ENV TZ ${TZ}
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

RUN chown -R mysql:root /var/lib/mysql/

COPY my.cnf /etc/mysql/conf.d/my.cnf

CMD ["mysqld --ignore-db-dir=lost+found"]

EXPOSE 3306

但是,我仍然遇到上述错误。 你对这个解决方案有什么想法吗?

谢谢,

1 个答案:

答案 0 :(得分:0)

我有一个类似的问题。为了解决它,您必须

  1. 转到C:\Program Files\MySQL\MySQL Server 5.7
  2. 您将找到一个名为data的文件夹。将其重命名为data1
  3. 以管理员身份启动命令提示符。
  4. 执行mysqld --initialize-insecure
  5. 转到控制面板中的服务,停止所有与MySql相关的服务,例如MySQL57
  6. 开始MySQL