node.js - Docker 和 Mac OSX 的权限问题

标签 node.js mongodb docker docker-compose

我正在运行 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

有关此问题的更多信息:

https://github.com/docker/machine/issues/1826

关于node.js - Docker 和 Mac OSX 的权限问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36788162/

相关文章:

javascript - Sequelize 语法错误

linux - 未授权查询 mongodb 上的 admin.system.namespaces

node.js - 在 MongoDB 中分区数据的最佳实践是什么?

ruby-on-rails - Rails 和 mongo 嵌入关系

跨多个磁盘的 Docker 镜像

docker - 如果使用 docker 部署,为什么 MERN 应用程序无法与后端通信?

node.js - MongoDB 与 MongoLab 的连接在 Heroku 上的 NodeJS 中超时

json - Node : saving JSON to MongoDB

node.js - 端口 80 的 HTTPS 和 SSL 问题

ruby-on-rails - Docker 容器未在端口 3000 上公开 Rails 应用程序