Docker和Mac OSX的权限问题

时间:2016-04-22 07:59:38

标签: node.js mongodb docker docker-compose

我正在运行MacOSX 10.11,我最近试图将所有项目都停靠。

尝试使用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时,我都会遇到以下错误:

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文件夹中但是我看到一个线程说明一旦卷安装后你就不能在容器中放入并且我可以确认它什么都不做。但是因为我使用的是docker-compose文件,所以在安装音量之前我不能这样做。 你有什么想法吗?

2 个答案:

答案 0 :(得分:1)

在MacOS上使用docker-machine,您只能在家庭主机目录中绑定卷。其他目录不起作用,因为它们不在VBox共享的文件夹中。您可以使用VBoxManage在用户主页之外共享您的文件夹: https://www.virtualbox.org/manual/ch08.html#vboxmanage-sharedfolder

有关此问题的详细信息:

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

答案 1 :(得分:0)

您确实需要从主机系统安装数据目录吗?你不能只为数据文件夹使用容器卷吗?

信息仍将保留在容器中。

示例:

version: '2'
volumes:
  mongo_data: {}
services:
  mongo-app:
    image: mongo:latest
    volumes:
      - mongo_data:/data/db
    expose:
      - "27017"
    ports:
      - "27017:27017"
    command: "--smallfiles --dbpath /data/db"

来源: