Docker의 python : x.x.x-alpine image에서 django 앱을 시작하여 migrate 할 때 "Cannot use ImageField because Pillow is not installed"오류가 발생하는 문제

Django 앱을 Docker에 올려 프로덕션 환경에 배포 할 때 발생한 문제입니다.
Django는 Image 파일을 다룰 때 Pillow라는 라이브러리를 사용하지만,이 라이브러리가 어색하고 오류가 발생하기 쉽습니다.
다음 Dockerfile을 사용하여 빌드합니다.

Dockerfile
###########
# BUILDER #
###########

# pull official base image
FROM python:3.7.3-alpine as builder

# set work directory
WORKDIR /usr/src/app

# set environment variables
#ENV PATH="/scripts:${PATH}"
ENV PYTHONUNBUFFERD 1
ENV PYTHONDONTWRITEBYTECODE 1

# install psycopg2 dependencies
RUN apk add --update --no-cache --virtual .tmp-build-deps postgresql-client jpeg-dev \
    .tmp-build-deps gcc build-base python3-dev musl-dev linux-headers \
    postgresql-dev
RUN apk add --update --no-cache --virtual .build-deps build-base python3-dev musl-dev \
    libc-dev linux-headers postgresql-dev musl-dev zlib zlib-dev gettext \
    postgresql-client gettext-dev libjpeg-turbo pcre
RUN apk add --update libxml2-dev libxslt-dev libffi-dev gcc libgcc openssl-dev curl
RUN apk add --update jpeg-dev zlib-dev freetype-dev lcms2-dev openjpeg-dev tiff-dev tk-dev tcl-dev libjpeg
RUN apk add --no-cache jpeg

# lint
RUN pip install --upgrade pip
RUN pip install --upgrade setuptools
RUN pip install flake8
RUN pip install pillow
COPY . .
RUN flake8 --ignore=E501,F401 .

# install dependencies
COPY ./requirements.txt .
RUN pip wheel --no-cache-dir --no-deps --wheel-dir /usr/src/app/wheels -r requirements.txt
RUN apk del .tmp-build-deps

#########
# FINAL #
#########

# pull official base image
FROM python:3.7.3-alpine

# create directory for the app user
RUN mkdir -p /home/app

# create the app user
RUN addgroup -S app && adduser -S app -G app
COPY --from=builder /usr/local/lib/python3.7/site-packages /usr/local/lib/python3.7/site-packages

# create the appropriate directories
ENV HOME=/home/app
ENV APP_HOME=/home/app/web
RUN mkdir $APP_HOME
#RUN mkdir $APP_HOME/staticfiles
#RUN mkdir $APP_HOME/mediafiles
WORKDIR $APP_HOME

# install dependencies
RUN apk update && apk add libpq
COPY --from=builder /usr/src/app/wheels /wheels
COPY --from=builder /usr/src/app/requirements.txt .
RUN pip install --no-cache /wheels/*
#RUN pip install pillow

# copy entrypoint-prod.sh
COPY ./entrypoint.prod.sh $APP_HOME

# copy project
COPY . $APP_HOME

# chown all the files to the app user
RUN chown -R app:app $APP_HOME

# change to the app user
USER app

#RUN chmod +x /home/app/web/entrypoint.prod.sh

# run entrypoint.prod.sh
ENTRYPOINT ["/home/app/web/entrypoint.prod.sh"]:


docker-compose.yml은 다음과 같이합니다.

docker-compose.yml
version: '3.7'

services:
  web:
    build:
      context: ./app
      dockerfile: Dockerfile
    command: gunicorn backend.wsgi:application --bind 0.0.0.0:8000
    ports:
      - 8000:8000
    env_file:
      - ./.env.dev
    depends_on:
      - db
  db:
    image: postgres:12.0-alpine
    volumes:
      - postgres_data:/var/lib/postgresql/data/
    environment:
      - POSTGRES_USER=hello_django
      - POSTGRES_PASSWORD=hello_django
      - POSTGRES_DB=hello_django_dev
      - POSTGRES_HOST_AUTH_METHOD=trust
  nginx:
    build: ./nginx
    ports:
      - 1337:80
    depends_on:
      - web

volumes:
  postgres_data:



이렇게 쓰고 docker-compose up -d build하고,
docker-compose exec web python manage.py migrate하면,
기사 제목과 같이 "Cannot use ImageField because Pillow is not installed"오류가 발생합니다.


오류 문에 따라 docker-compose exec web python -m pip install Pillow 해보십시오.


또는 docker-compose exec web python -m pip list에서 라이브러리를 보면 Pillow가 안전하게 설치됩니다.
왜......

살펴보면 이 오류는 자주 발생하는 것 같고, pip install -m Pillow를 쪼개든지, alpine에 apk로 여러가지 jpeg-dev라든지의 dependeencies를 넣어라든가, python과 pillow의 version을 바꾸라든지 나옵니다. 여러가지 시험해 보았습니다만, 아무래도, alpine 이미지에서는 Pillow를 취급할 수 없는 것 같습니다.

Docker 이미지를 python-x.x.x-alpine에서 python-x.x-buster로 변경하고 여러 dependencies를 넣고 build했는데, 무사히 migrate 할 수 있었습니다. 해결책으로는 간단합니다. django on docker(alpine)로 Pillow를 사용할 수 없습니다. 이상입니다.

좋은 웹페이지 즐겨찾기