我有一个运行MariaDB的Docker容器,并且在Dockerfile中为图像我已经将SQL文件复制到容器中的某个位置:
FROM mariadb
RUN mkdir /adhoc_scripts
COPY bootup.sql /adhoc_scripts
容器启动后,我能够在容器中输入shell并确认sql文件确实存在于指定位置:
$ docker exec -it my_mariadb_container bash
root@6e3f4b9abe17:/# ls -lt /adhoc_scripts/
total 4
-rw-r--r-- 1 root root 1839 Apr 10 18:35 bootup.sql
但是,当我退出容器并尝试调用以下命令时:
docker exec -it my_mariadb_container bash \
mysql mydb -u root -prootpass \
< /adhoc_scripts/bootup.sql
我收到此错误:
-bash: /adhoc_scripts/bootup.sql: No such file or directory
我做错了什么?
EDIT1:我也尝试将/adhoc-scripts
的权限更改为777,但这并没有帮助。
答案 0 :(得分:2)
这是因为<
运算符对整个docker exec ...
命令而不是bash mysql ...
部分进行操作。
错误消息很明确:您的bash(容器外)正在尝试解释/adhoc_scripts/bootup.sql
文件。
要解决此问题,请尝试以下方法:
docker exec -it my_mariadb_container bash -c "mysql mydb -u root -prootpass < /adhoc_scripts/bootup.sql"