0
我正在创建带有一些示例数据的mysql映像。我在图像创建过程中尝试启动mysql过程时遇到了错误,因此我可以将数据放入图像中。下面是我的文件结构无法通过Docker中的套接字错误连接到本地MySQL服务器
[DockerFile]
FROM mysql:5.6.29
# MYSQL volumes
VOLUME ["/etc/mysql", "/var/lib/mysql"]
COPY data_dump.sql /tmp/
COPY init_db.sh /tmp/
RUN chmod -R 777 /tmp/init_db.sh
RUN chmod -R 777 /tmp/data_dump.sql
RUN /tmp/init_db.sh
EXPOSE 3306
[init_db.sh]
#!/bin/bash
echo "starting the bash command"
/usr/bin/mysqld_safe &
echo "started the mysqld_safe process"
sleep 15
mysql -u root -h localhost -e "CREATE DATABASE test"
echo "Done creating the test schema"
mysql -u root -h localhost test < /tmp/data_dump.sql
echo "Done creating the test data"
我收到以下错误:
started the mysqld_safe process
170906 13:56:49 mysqld_safe Logging to '/var/lib/mysql/bcad5a346f31.err'.
170906 13:56:49 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
170906 13:56:49 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
Done creating the test schema
Done creating the test data
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
我觉得你的mysql窗格上,我的意思是说,MySQL是在3306端口监听你的地方,所以请关闭然后尝试运行docker file.It将运行比...谢谢 –
@AamirMeman我证实,3306没有被任何本地实例的Mysql使用 –
https://www.youtube.com/watch?v=oXjJRrbKjp0 ,这个视频可能会帮助你比... –