Разрешение отклонено при миграции django в докере

Я использую docker compose с django-postgres-rabbitmq

Все идет хорошо, даже контейнер django запущен и работает до такой степени, что я хочу makemigrations, он останавливается с django-celery-beat

Migrations for 'django_celery_beat':
django_1        |   /usr/local/lib/python2.7/site-packages/django_celery_beat/migrations/0005_auto_20190512_1531.py
django_1        |     - Alter field event on solarschedule
django_1        | Traceback (most recent call last):
django_1        |   File "/app/manage.py", line 10, in <module>
django_1        |     execute_from_command_line(sys.argv)
django_1        |   File "/usr/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 364, in execute_from_command_line
django_1        |     utility.execute()
django_1        |   File "/usr/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 356, in execute
django_1        |     self.fetch_command(subcommand).run_from_argv(self.argv)
django_1        |   File "/usr/local/lib/python2.7/site-packages/django/core/management/base.py", line 283, in run_from_argv
django_1        |     self.execute(*args, **cmd_options)
django_1        |   File "/usr/local/lib/python2.7/site-packages/django/core/management/base.py", line 330, in execute
django_1        |     output = self.handle(*args, **options)
django_1        |   File "/usr/local/lib/python2.7/site-packages/django/core/management/commands/makemigrations.py", line 193, in handle
django_1        |     self.write_migration_files(changes)
django_1        |   File "/usr/local/lib/python2.7/site-packages/django/core/management/commands/makemigrations.py", line 232, in write_migration_files
django_1        |     with io.open(writer.path, "w", encoding='utf-8') as fh:
django_1        | IOError: [Errno 13] Permission denied: '/usr/local/lib/python2.7/site-packages/django_celery_beat/migrations/0005_auto_20190512_1531.py

в то время как пользовательская модель записывается при миграции, и она должна быть унаследована от AbstractUser в самом django, но там не возникает ошибка разрешения

django_1        | Migrations for 'users':
django_1        |   users/migrations/0001_initial.py
django_1        |     - Create model UserAccount
django_1        |     - Create model Branch
django_1        |     - Create model Organization
django_1        |     - Add field organization to branch
django_1        |     - Add field bills_groups to useraccount
django_1        |     - Add field branch to useraccount
django_1        |     - Add field groups to useraccount
django_1        |     - Add field user_permissions to useraccount

поэтому я попытался добавить пользователя sudo в alpine python-2.7, но на самом деле мне не удалось запустить эту команду с разрешением sudo

Итак, что мне делать, запускать образ с помощью virtualenv внутри докера или есть какие-то настройки, чтобы исправить это?

Докерфайл

FROM python:2.7-alpine

ENV PYTHONUNBUFFERED 1
RUN addgroup -S django \
    && adduser -S -G django django

RUN apk update \
  && apk add sudo \
  # psycopg2 dependencies
  && apk add --virtual build-deps gcc python-dev musl-dev \
  && apk add postgresql-dev \
  # CFFI dependencies
  && apk add libffi-dev py-cffi \
  # Translations dependencies
  && apk add gettext \
  # https://docs.djangoproject.com/en/dev/ref/django-admin/#dbshell
  && apk add postgresql-client

# Requirements are installed here to ensure they will be cached.
COPY ./requirements.txt /requirements.txt
RUN pip install --no-cache-dir --default-timeout=100 -r /requirements.txt \
        && rm -rf /requirements

COPY ./compose/testing/django/entrypoint /entrypoint
RUN sed -i 's/\r//' /entrypoint
RUN chmod +x /entrypoint
RUN chown django /entrypoint

COPY ./compose/testing/django/start /start
RUN sed -i 's/\r//' /start
RUN chmod +x /start
RUN chown django /start

COPY . /app

RUN chown -R django /app

USER django

WORKDIR /app

ENTRYPOINT ["/entrypoint"]

докер-compose.yml

version: '3'

volumes:
  production_postgres_data: {}
  production_postgres_data_backups: {}

services:
  django: &django
    build:
      context: .
      dockerfile: ./compose/testing/django/Dockerfile
    image: panel_testing_django
    depends_on:
      - postgres
      - rabbitmq
    env_file:
      - ./.envs/.production/.django
      - ./.envs/.production/.postgres
    command: /start
    ports:
      - "8000"
    expose:
      - "8000"

  postgres:
    build:
      context: .
      dockerfile: ./compose/staging/postgres/Dockerfile
    image: panel_testing_postgres
    env_file:
      - ./.envs/.production/.postgres
    volumes:
      - production_postgres_data:/var/lib/postgresql/data
      - production_postgres_data_backups:/backups
    ports:
     - "5432"

  rabbitmq:
    hostname: rabbit
    image: rabbitmq:3-management
    environment:
      - RABBITMQ_DEFAULT_USER=admin
      - RABBITMQ_DEFAULT_PASS=mypass
    ports:
      - "5672:5672"  
      - "15672:15672"

  celeryworker:
    <<: *django
    image: panel_testing_celeryworker
    command: /start-celeryworker

  celerybeat:
    <<: *django
    image: panel_testing_celerybeat
    command: /start-celerybeat

  flower:
    <<: *django
    image: panel_testing_flower
    ports:
      - "5555:5555"
    command: /start-flower

person A.Raouf    schedule 12.05.2019    source источник
comment
Вы можете добавить свои файлы Dockerfile и docker-compose?   -  person JPG    schedule 12.05.2019
comment
Я сделал, проверь их   -  person A.Raouf    schedule 12.05.2019
comment
Я добавил один ответ ниже, попробуйте :) надеюсь, что это решит проблему :)   -  person JPG    schedule 12.05.2019
comment
Он пытается записать файл в /usr/local/lib, который, вероятно, принадлежит пользователю root, но затем Dockerfile переключается на пользователя django, поэтому у него больше нет прав на запись в этот файл. Почему эти файлы миграции хранятся внутри /usr/local/lib? Они должны быть там, где у вас есть доступ для записи, например, в папке /app.   -  person solarc    schedule 15.05.2019


Ответы (3)


Сегодня была более менее такая же проблема. Я создал проект с помощью docker и при первой попытке запустить makemigrations получил эту ошибку:

PermissionError: [Errno 13] Permission denied: '/usr/local/lib/python3.7/site-packages/django/contrib/admin/migrations/0004_auto_20190515_1649.py'

Я решил эту проблему, запустив makemigrations, указав имя приложения (core — это имя приложения), например:

docker-compose run web_app sh -c "python manage.py makemigrations core"
person osmay88    schedule 15.05.2019

Я только что использовал virtualenv внутри докера и передал право собственности моему пользователю на среду site-packages dir.

RUN pip install virtualenv && virtualenv -p python /app/venv
RUN /app/venv/bin/pip install -r req.txt
RUN /app/venv/bin/python /app/code/manage.py makemigrations

и ГОТОВО

person A.Raouf    schedule 01.07.2019

Я работаю в Linux, и в моем случае это был просто случай перехода в папку, в которой хранятся миграции, и предоставления достаточных разрешений самой папке.

Например:

chmod . 666
person James Bradbury    schedule 02.03.2020