【发布时间】:2020-04-15 04:51:03
【问题描述】:
我是一个低级的前端开发人员,试图通过后端技能来提高,为此我在 nodejs 中编写了我的 API,并使用 GitLab、AWS EC2、docker 和 pm2 来为后端提供服务。
我几乎在 GitLab 中有一个基本的 CI/CD 设置,但我有一个问题,我的 docker 容器似乎在运行 pm2 后立即退出,我不知道如何让它坚持下去。你能帮忙吗?
我很简单的docker-compose.yml 看起来是这样的:
version: '3.7'
services:
api:
image: some-repo/some-image:latest
我的.gitlab-c.yml 看起来像这样:
image: docker:18.09.7
variables:
DOCKER_REPO: some-repo
IMAGE_BASE_NAME: some-image
IMAGE: $DOCKER_REPO/$IMAGE_BASE_NAME:$CI_COMMIT_REF_SLUG
services:
- docker:18.09.7-dind
before_script:
- docker login -u "$DOCKER_REGISTRY_USER" -p "$DOCKER_REGISTRY_PASSWORD"
after_script:
- docker logout
stages:
- build
- deploy
build:
stage: build
script:
- docker build . -t $IMAGE -f $PWD/staging.Dockerfile
- docker push $IMAGE
- echo $PWD
deploy:
stage: deploy
variables:
RELEASE_IMAGE: $DOCKER_REPO/$IMAGE_BASE_NAME:latest
script:
- docker pull $IMAGE
- docker tag $IMAGE $IMAGE
- docker push $IMAGE
- docker tag $IMAGE $RELEASE_IMAGE
- docker push $RELEASE_IMAGE
- apk add openssh-client
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
- chmod 600 $AWS_KEY
- ssh-keyscan www.gitlab.com >> ~/.ssh/known_hosts
- ssh -i $AWS_KEY $AWS_URL "cd /home/ubuntu"
- ssh -i $AWS_KEY $AWS_URL "docker system prune -a -f"
- ssh -i $AWS_KEY $AWS_URL "docker login -u $DOCKER_REGISTRY_USER -p $DOCKER_REGISTRY_PASSWORD"
- ssh -i $AWS_KEY $AWS_URL "docker pull $RELEASE_IMAGE"
- ssh -i $AWS_KEY $AWS_URL "/snap/bin/docker-compose stop"
- ssh -i $AWS_KEY $AWS_URL "/snap/bin/docker-compose up -d"
- ssh -i $AWS_KEY $AWS_URL "docker logout"
我的staging.Dockerfile 看起来像这样:
FROM node:latest
LABEL author="Mark Norgate"
WORKDIR /var/www/api
ENV ENVIRONMENT_CONFIG=staging
COPY ./src ./src
COPY ./package.json ./package.json
COPY ./tsconfig.json ./tsconfig.json
COPY ./.pm2/staging/ecosystem.config.js ./ecosystem.config.js
COPY ./credentials/some-credentials.json ./some-credentials.json
RUN npm install
RUN npm install --global typescript
RUN tsc -p .
RUN npm install --global pm2
EXPOSE 3001
EXPOSE 3002
EXPOSE 27017
ENTRYPOINT ["pm2", "start", "/var/www/api/ecosystem.config.js"]
而我的ecosystem.config.js 看起来像这样:
module.exports = {
apps : [{
name: 'API',
script: '/var/www/api/lib/server.js',
env: {
GOOGLE_APPLICATION_CREDENTIALS: '/var/www/api/some-credentials.json'
}
}]
};
现在看来这一切正常;除了,正如我所说,一旦执行此pm2 命令,容器就会退出。我认为这可能就像在分离模式下运行 docker-compose up 一样简单,但这并没有帮助。
谁能发现我的错误/遗漏?
【问题讨论】:
-
运行
docker-compose up后容器日志显示什么?
标签: node.js docker amazon-ec2 docker-compose pm2