Mam plik Docker, który przygotowuję, aby zainstalować waniliowe środowisko python (w którym będę instalować aplikację, ale w późniejszym terminie).
FROM ubuntu:12.04
# required to build certain python libraries
RUN apt-get install python-dev -y
# install pip - canonical installation instructions from pip-installer.org
# http://www.pip-installer.org/en/latest/installing.html
ADD https://bitbucket.org/pypa/setuptools/raw/bootstrap/ez_setup.py /tmp/ez_setup.py
ADD https://raw.github.com/pypa/pip/master/contrib/get-pip.py /tmp/get-pip.py
RUN python /tmp/ez_setup.py
RUN python /tmp/get-pip.py
RUN pip install --upgrade pip
# install and configure virtualenv
RUN pip install virtualenv
RUN pip install virtualenvwrapper
ENV WORKON_HOME ~/.virtualenvs
RUN mkdir -p $WORKON_HOME
RUN source /usr/local/bin/virtualenvwrapper.sh
Kompilacja działa poprawnie do ostatniej linii, gdzie otrzymuję następujący wyjątek:
[previous steps 1-9 removed for clarity]
...
Successfully installed virtualenvwrapper virtualenv-clone stevedore
Cleaning up...
---> 1fc253a8f860
Step 10 : ENV WORKON_HOME ~/.virtualenvs
---> Running in 8b0145d2c80d
---> 0f91a5d96013
Step 11 : RUN mkdir -p $WORKON_HOME
---> Running in 9d2552712ddf
---> 3a87364c7b45
Step 12 : RUN source /usr/local/bin/virtualenvwrapper.sh
---> Running in c13a187261ec
/bin/sh: 1: source: not found
Jeśli przejdę ls
do tego katalogu (tylko w celu sprawdzenia, czy poprzednie kroki zostały popełnione), widzę, że pliki istnieją zgodnie z oczekiwaniami:
$ docker run 3a87 ls /usr/local/bin
easy_install
easy_install-2.7
pip
pip-2.7
virtualenv
virtualenv-2.7
virtualenv-clone
virtualenvwrapper.sh
virtualenvwrapper_lazy.sh
Jeśli spróbuję po prostu uruchomić source
polecenie, pojawia się ten sam błąd „nie znaleziono” jak powyżej. Jeśli jednak uruchomię interaktywną sesję powłoki, źródło działa:
$ docker run 3a87 bash
source
bash: line 1: source: filename argument required
source: usage: source filename [arguments]
Mogę uruchomić skrypt stąd, a następnie szczęśliwie dostępu workon
, mkvirtualenv
itd.
Zrobiłem trochę kopania i początkowo wydawało się, że problem może polegać na różnicy między bash jako powłoką logowania Ubuntu , a dash jako powłoką systemu Ubuntu , dash nie obsługuje source
polecenia.
Jednak wydaje się, że odpowiedzią na to jest użycie „”. zamiast source
, ale to tylko powoduje, że środowisko wykonawcze Dockera wysadza się w powietrze z wyjątkiem paniki typu go.
Jaki jest najlepszy sposób na uruchomienie skryptu powłoki z instrukcji RUN Dockerfile, aby obejść ten problem (uruchamiam domyślny obraz podstawowy dla Ubuntu 12.04 LTS).
CMD source activate django-py35