提问人:user3523406 提问时间:3/16/2018 更新时间:3/17/2018 访问量:2534
错误 2002 (HY000):无法通过套接字连接到本地 MySQL 服务器
ERROR 2002 (HY000): Can't connect to local MySQL server through socket
问:
我在尝试连接到数据库时在 debian 测试中遇到了此错误。ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2 "No such file or directory")
我在 Dockerfile 中进行了以下设置:
FROM debian:testing
RUN apt update && apt full-upgrade -y \
&& apt install -y --no-install-recommends \
apache2 \
php \
libapache2-mod-php \
mariadb-server \
php-mysql \
openjdk-9-jdk \
git \
&& rm -rf /var/lib/apt/lists/*
RUN /etc/init.d/mysql start
# Copy the database schema to the /data directory
ADD ./mgsv.sql /tmp/
# Permit root login without password from outside container.
RUN mysql -e "GRANT ALL ON *.* TO root@'%' IDENTIFIED BY '' WITH GRANT OPTION"
# create the default database from the ADDed file.
RUN mysql < mgsv.sql
RUN git clone https://github.com/qunfengdong/mGSV.git
mgsv.sql 如下所示:
CREATE DATABASE mgsv;
CREATE USER 'mgsv_user'@'localhost' IDENTIFIED BY 'mgsvpass';
GRANT SELECT, INSERT, CREATE, DROP ON mgsv.* TO 'mgsvuser'@'localhost';
use mgsv;
CREATE TABLE IF NOT EXISTS `userinfo` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`email` text NOT NULL,
`hash` text NOT NULL,
`synfilename` text NOT NULL,
`annfilename` text NOT NULL,
`url` text NOT NULL,
`session_id` text NOT NULL,
`annImage` int(5) NOT NULL,
`create_on` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;
我错过了什么?
先谢谢你
答:
0赞
whites11
3/17/2018
#1
你误解了 docker 的工作原理。
您编写的 dockerfile 不是脚本。每个命令都是一个独立的命令,并且仅具有为它将生成的最终 docker 映像创建层的效果。
这意味着当您在以下命令中运行时,您将无法连接到 mysql 服务。它根本没有运行。/etc/init.d/mysql start
所有数据导入操作都必须在容器 is 时完成,而不是在 .running
building
我的建议是使用预构建的 mysql 容器映像,也许您可以在此处找到 https://hub.docker.com/_/mysql/,并且在容器运行后,您可以手动创建数据库。
如果您需要自动创建数据库,则需要创建一个自定义映像,在其中更新 docker 映像的 or,以便在 DBMS 启动后执行数据库创建,但老实说,恕我直言,这不是一个很好的做法。entrypoint
cmd
评论