2016-09-20 1 views

답변

1

내가 과거에 수행 한 작업은 Dockerfile에 정의 된 진입 점을 쉘 스크립트로 만든 다음 해당 스크립트 내에서 node 명령을 실행하는 것입니다.

그래서 내 Dockerfile에 내가 가진이 -

ENTRYPOINT ["./docker-start.sh"] 

그리고 내 docker-start.sh 스크립트이 포함

#! /bin/bash 

# Initialization logic can go here 

echo "Starting node..." 
node start.js $* # The $* allows me to pass command line arguments that were passed to the docker run command. 

# Cleanup logic can go here 
+0

은 그럴 가능성이 있습니다. – Oleg

0

인증서를 이미지에 저장하면 이미지에서 실행하는 모든 컨테이너에 대해 인증서가 동일하게 유지됩니까? 그럼 당신은 할 수 있다면 그 Dockerfile에서 : 당신 docker build이의 RUN 명령의 출력이 있으므로 인증서 표시가 영구적으로 저장하고 당신이 만들 필요가 없습니다, 이미지에 저장됩니다

COPY create-certs.sh /create-certs.sh 
RUN /create-certs.sh 
CMD ["node", "etc."] 

컨테이너가 시작될 때.

각 컨테이너에 대한 요청에 따라 인증서를 작성해야하는 경우 여러 단계를 수행하는 부트 스트랩 쉘 스크립트를 사용할 수 있습니다. 인증서가 존재하는지 확인하고 필요한 경우 생성 한 다음 노드 응용 프로그램을 시작하십시오. 부트 스트랩 쉘 스크립트는 CMD에 사용하는 스크립트입니다.

+0

그 트릭, certs 컨테이너의 각 실행마다 다릅니다. – Oleg

+0

문제가되지 않아야합니다. 시작 로직을'bootstrap.sh'에 랩핑하고 스크립트의 마지막 명령이 노드 애플리케이션을 시작하면 스크립트 프로세스가 계속 실행되고 Docker가 모니터링합니다. –

+1

이것은 기본적으로 @Lix가 제안한 것입니까? – Oleg

관련 문제