我对这个问题束手无策,希望你们能帮助我。在使用docker-machine的OSX 10.11.2中,我有一个docker-compose文件,应该构建一个本地Dockerfile并连接一个MySQL容器。MySQL容器应该挂载一个本地文件夹,其中我存储了我的数据库数据,因此,如果容器或虚拟机关闭,我可以重新启动它而不会丢失数据。问题是,当我运行它时,它会抛出一个权限错误:
db_1 | 2015-12-23 19:17:59 7facaa89b740 InnoDB: Operating system error number 13 in a file operation.
db_1 | InnoDB: The error means mysqld does not have the access rights to
db_1 | InnoDB: the directory.
我已经尝试了我能想到的所有排列组合来使这个工作。我正在阅读相关文献,可能与docker-machine如何处理OSX权限有关,但是docker-machine的文档说它会挂载/Users
文件夹,所以这不应该是个问题。
这是docker-compose.yml
:
web:
build: .
ports:
- "3000:3000"
links:
- db
db:
image: mysql:5.6
ports:
- "3306:3306"
volumes:
- /Users/me/Development/mysql-data:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: mypass
有什么想法吗?我觉得这可能是非常简单的事情。任何帮助将不胜感激!
编辑:
- 主机 -
drwxr-xr-x 7 me staff 238 Dec 23 12:10 mysql-data/
- 虚拟机 -
drwxr-xr-x 1 docker staff 238 Dec 23 20:10 mysql-data/
对于容器,它无法通过挂载卷来运行。没有-v
装载,它是:
- 容器 -
drwxr-xr-x 4 mysql mysql 4096 Dec 24 00:37 mysql
ls -lh
命令在三个位置(主机、虚拟机、容器)中对数据目录的输出将有助于调试。我认为最有可能发生的情况是该目录归属于 root,不允许 mysql 用户创建新文件。 - dnephin