我正在运行 MacOSX 10.11,最近我尝试对我的所有项目进行 dockerize。
我在尝试使用 docker-compose 运行 mongoDB + NodeJS 应用程序时遇到问题。
这是我的 docker-compose 脚本:
version: '2'
services:
mongodata:
image: mongo:latest
volumes:
- "${APP_DB}:/data"
command: "--break-mongo"
mongo-app:
image: mongo:latest
volumes_from:
- "mongodata"
expose:
- "27017"
ports:
- "27017:27017"
command: "--smallfiles --dbpath /data"
web:
build: .
volumes:
- .:/usr/src/app
ports:
- "3000:3000"
depends_on:
- mongo-app
links:
- mongo-app
environment:
- PORT=3000
所以基本上我有一个仅包含卷的容器来保存我的文件。然后我根据该卷运行 mongo,然后运行我的 NodeJS 应用程序。
但是每次我尝试运行 docker-compose up 时,都会出现以下错误:
mongo-app_1 | 2016-04-22T07:14:05.931+0000 I CONTROL [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data 64-bit host=4c43c9e20014
mongo-app_1 | 2016-04-22T07:14:05.931+0000 I CONTROL [initandlisten] db version v3.2.5
mongodata_1 | try 'mongod --help' for more information
mongo-app_1 | 2016-04-22T07:14:05.932+0000 I CONTROL [initandlisten] git version: 34e65e5383f7ea1726332cb175b73077ec4a1b02
mongo-app_1 | 2016-04-22T07:14:05.932+0000 I CONTROL [initandlisten] OpenSSL version: OpenSSL 1.0.1e 11 Feb 2013
mongo-app_1 | 2016-04-22T07:14:05.932+0000 I CONTROL [initandlisten] allocator: tcmalloc
mongo-app_1 | 2016-04-22T07:14:05.932+0000 I CONTROL [initandlisten] modules: none
mongo-app_1 | 2016-04-22T07:14:05.933+0000 I CONTROL [initandlisten] build environment:
mongo-app_1 | 2016-04-22T07:14:05.933+0000 I CONTROL [initandlisten] distmod: debian71
mongo-app_1 | 2016-04-22T07:14:05.933+0000 I CONTROL [initandlisten] distarch: x86_64
mongo-app_1 | 2016-04-22T07:14:05.933+0000 I CONTROL [initandlisten] target_arch: x86_64
mongo-app_1 | 2016-04-22T07:14:05.934+0000 I CONTROL [initandlisten] options: { storage: { dbPath: "/data", mmapv1: { smallFiles: true } } }
mongo-app_1 | 2016-04-22T07:14:05.947+0000 I - [initandlisten] Detected data files in /data created by the 'mmapv1' storage engine, so setting the active storage engine to 'mmapv1'.
mongo-app_1 | 2016-04-22T07:14:05.958+0000 W - [initandlisten] Detected unclean shutdown - /data/mongod.lock is not empty.
mongo-app_1 | 2016-04-22T07:14:05.959+0000 I STORAGE [initandlisten] exception in initAndListen: 98 Unable to create/open lock file: /data/mongod.lock errno:13 Permission denied Is a mongod instance already running?, terminating
mongo-app_1 | 2016-04-22T07:14:05.964+0000 I CONTROL [initandlisten] dbexit: rc: 100
据我所知,这种情况仅发生在 MacOSX 上,我尝试 CHOWN + CHMOD/data 文件夹,但我看到一个线程说,一旦安装了卷,就无法在容器中进行 CHOWN,我可以确认它什么也不做。但由于我使用的是 docker-compose 文件,因此在安装卷之前我无法执行此操作。 你有什么想法吗?
最佳答案
在 MacOS 上使用 docker-machine,您只能在主主机目录内绑定(bind)卷。其他目录不起作用,因为它们不在 VBox 共享的文件夹中。您可以使用 VBoxManage
在用户主目录之外共享文件夹:
https://www.virtualbox.org/manual/ch08.html#vboxmanage-sharedfolder
有关此问题的更多信息:
关于node.js - Docker 和 Mac OSX 的权限问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36788162/