docker-compose up postgresql 错误,chown: changing ownership of ‘/var/lib/postgresql/data’: Operation not permitted

docker-compose up postgresql error, chown: changing ownership of ‘/var/lib/postgresql/data’: Operation not permitted

我在一个项目中工作,我们使用 docker。该项目在上周五之前一直很好,今天我启动了我的计算机(mac mini - macOS Sierra version 10.12.5 (16F73))并出现错误。 我正在尝试 运行 docker-compose -f dev.yml -f docker-compose.yml up,但是当我执行它时 returns 以下消息:

db_1 | chmod: changing permissions of ‘/var/lib/postgresql/data’: Operation not permitted.

我删除了所有 docker 容器和图像 docker rm $(docker ps -a -q) docker rmi $(docker images -q)但错误仍然存​​在。

我的docker-compose.yml是这样的:

 version: '2'

 services:

 rabbitmq:
     restart: always
     image: rabbitmq:3.6
     environment:
       RABBITMQ_DEFAULT_USER: my_user
       RABBITMQ_DEFAULT_PASS: my_password
     ports:
       - "5672:5672"
       - "15672:15672"
   django:
     build: ./django
     command: gunicorn contactto.wsgi:application -b 0.0.0.0:8000
     environment: 
       - "TZ=Brazil/East"
     restart: always
     volumes: 
       - ./django:/usr/src/app
       - ./django/static:/usr/src/app/contactto/static
       - ./logs:/logs/
       - /asterisk/:/etc/asterisk/
     ports:
       - "8000:8000"
     links:
       - rabbitmq:rabbitmq
   node:
     build: ./node_6_8
     environment:
       - "TZ=Brazil/East"
     volumes_from:
       - django
   nginx:
     build: ./nginx
     restart: always
     environment: 
       - "TZ=Brazil/East"
     ports:
       - "80:80"
       - "443:443"
     volumes: 
       - /www/static
     volumes_from:
       - django
     links:
       - django:django
   worker:
     build: ./django
     command: su -m worker -c "celery worker -A contactto.celeryconf -Q default -n default@%h"
     environment: 
       - "TZ=Brazil/East"
     restart: always
     volumes:
       - ./django:/usr/src/app
       - ./django/static:/usr/src/app/contactto/static
       - ./logs:/logs/
       - /asterisk/:/etc/asterisk/
     links:
       - rabbitmq:rabbitmq

 volumes: 
   dbdata:

我的dev.yml是这样的:

version: '2'

services:
  db:
    image: postgres:9.5
    restart: always
    environment:
      POSTGRES_USER: my_user
      POSTGRES_PASSWORD: my_password
      POSTGRES_DB: my_db
    volumes:
      - /psqldata:/var/lib/postgresql/data
  django:
    environment:
      - "DJANGO_CONFIG_MODE=Development"
    depends_on:
      - db
  worker:
    environment:
      - "DJANGO_CONFIG_MODE=Development"
    links:
      - db:db

任何帮助将不胜感激。

我在 / 进入并继续分析文件夹。比我在那里设置命令 ls -la 并且我看到该文件夹​​是 root 用户。首先,我删除了文件夹 sudo rm -rf psqldata,然后设置权限 sudo chmod 777 / 与我的用户 mkdir psqldata 创建文件夹,现在它可以正常工作了。我不知道为什么它在工作之前突然停止了。希望这个回答也能帮到你。

旧文件夹ls -la drwxr-xr-x 2 root wheel 68 Jun 19 14:58 psqldata

新建文件夹ls -la drwxr-xr-x 2 gtmiyabe wheel 68 Jun 20 10:07 psqldata