Próbuję dokerować moją aplikację node.js. Po zbudowaniu kontenera chcę, aby uruchamiał, git clone
a następnie uruchamiał serwer węzłów. Dlatego umieściłem te operacje w skrypcie .sh. I uruchom skrypt jako pojedyncze polecenie w ENTRYPOINT:
FROM ubuntu:14.04
RUN apt-get update && apt-get install -y build-essential libssl-dev gcc curl npm git
#install gcc 4.9
RUN apt-get install -y software-properties-common python-software-properties
RUN add-apt-repository -y ppa:ubuntu-toolchain-r/test
RUN apt-get update
RUN apt-get install -y libstdc++-4.9-dev
#install newst nodejs
RUN curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash -
RUN apt-get install -y nodejs
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app
ADD package.json /usr/src/app/
RUN npm install
ADD docker-entrypoint.sh /usr/src/app/
EXPOSE 8080
ENTRYPOINT ["/usr/src/app/docker-entrypoint.sh"]
Mój docker-entrypoint.sh wygląda tak:
git clone git@<repo>.git
git add remote upstream git@<upstream_repo>.git
/usr/bin/node server.js
Po zbudowaniu tego obrazu i uruchomieniu:
docker run --env NODE_ENV=development -p 8080:8080 -t -i <image>
Otrzymuję:
docker: Error response from daemon: oci runtime error: exec: "/usr/src/app/docker-entrypoint.sh": permission denied.
Otwieram do kontenera, a zgoda docker-entrypoint.sh to:
-rw-r--r-- 1 root root 292 Aug 10 18:41 docker-entrypoint.sh
trzy pytania:
Czy mój skrypt bash ma nieprawidłową składnię?
Jak zmienić uprawnienia do pliku bash przed dodaniem go do obrazu?
Jaki jest najlepszy sposób uruchamiania wielu poleceń git w punkcie wejścia bez użycia skryptu bash?
Dzięki.
.sh
rozszerzenie pozostawia mylące wrażenie na temat tego, którzy tłumacze mogą je wykonać. Możesz rozważyć usunięcie tego - nie jest konwencjonalne, że polecenia UNIX mają rozszerzenia ( ls.elf
na przykład nie uruchamiasz ).
exec
w ten sposób mieć muszlę? czy nie potrzebowałby bash
przedrostka.