Rails dockerized: непрерывная доставка с использованием Gitlab и Digitalocean - PullRequest
0 голосов
/ 16 апреля 2019

Я на самом деле пытаюсь настроить непрерывную доставку для докернизированного проекта Rails, размещенного на Gitlab.com.Я следовал этой статье , которая не имеет прямого отношения к среде Rails и которую я пытался адаптировать ... Очевидно, что безуспешно: (

Для контекста я создал три разных сервиса:db, webpacker и app.

Следуя вышеприведенной статье, вот мои .gitlab-ci.yml и docker-compose.staging2.yml (автоматическое развертывание):

image: docker
services:
  - docker:dind

cache:
  paths:
    - node_modules

variables:
  DOCKER_HOST: tcp://docker:2375/
  DOCKER_DRIVER: overlay2
  CONTAINER_CURRENT_IMAGE: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
  CONTAINER_LATEST_IMAGE: $CI_REGISTRY_IMAGE:latest
  CONTAINER_STABLE_IMAGE: $CI_REGISTRY_IMAGE:stable

stages:
  - test
  - build
  - release
  - deploy

before_script:
  - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
  - apk add --no-cache py-pip python-dev libffi-dev openssl-dev gcc libc-dev make
  - pip install docker-compose
  - docker-compose --version

test:
  stage: test
  script:
    - docker-compose build --pull
    # Here we will run tests when available...
  after_script:
    - docker-compose down
    - docker volume rm `docker volume ls -qf dangling=true`

build:
  stage: build
  script:
    - docker build -t $CONTAINER_CURRENT_IMAGE . --pull
    - docker push $CONTAINER_CURRENT_IMAGE

release-latest-image:
  stage: release
  only:
    - feat-dockerisation
  script:
    - docker pull $CONTAINER_CURRENT_IMAGE
    - docker tag $CONTAINER_CURRENT_IMAGE $CONTAINER_LATEST_IMAGE
    - docker push $CONTAINER_LATEST_IMAGE

release-stable-image:
  stage: release
  only:
    - feat-dockerisation
  script:
    - docker pull $CONTAINER_CURRENT_IMAGE
    - docker tag $CONTAINER_CURRENT_IMAGE $CONTAINER_STABLE_IMAGE
    - docker push $CONTAINER_STABLE_IMAGE

deploy_staging:
  stage: deploy
  only:
    - feat-dockerisation
  environment: production
  before_script:
    - mkdir -p ~/.ssh
    - echo "$DEPLOY_SERVER_PRIVATE_KEY" | tr -d '\r' > ~/.ssh/id_rsa
    - chmod 600 ~/.ssh/id_rsa
    - which ssh-agent || (apk add openssh-client)
    - eval $(ssh-agent -s)
    - ssh-add ~/.ssh/id_rsa
    - ssh-keyscan -H $DEPLOYMENT_SERVER_IP >> ~/.ssh/known_hosts
  script:
    - scp -rp ./docker-compose.staging2.yml root@${DEPLOYMENT_SERVER_IP}:~/
    - ssh root@$DEPLOYMENT_SERVER_IP "docker login -u ${CI_REGISTRY_USER} -p ${CI_REGISTRY_PASSWORD} ${CI_REGISTRY};
      docker-compose -f docker-compose.staging2.yml down;
      docker pull $CONTAINER_LATEST_IMAGE;
      docker-compose -f docker-compose.staging2.yml up -d"
version: '3'
services:
  db:
    image: postgres:11-alpine
    ports:
      - 5433:5432
    environment:
      POSTGRES_PASSWORD: postgres

  webpacker:
    image: registry.gitlab.com/soykje/beweeg-ror:latest
    command: [sh, -c, "yarn && bin/webpack-dev-server"]
    ports:
      - 3035:3035

  app:
    image: registry.gitlab.com/soykje/beweeg-ror:latest
    links:
      - db
      - webpacker
    ports:
      - 3000:3000

Я начинаю работать с Docker и CI / CD, поэтому ... Не могу найти, что я делаю неправильно: /

После того, как все задания успешно завершены на Gitlab CI / CD, когда я пытаюсь получить доступ к своему приложению на капле Docker, я ничего не получаю ... Когда я ssh на своей капле, все кажется в порядке, но я все еще не могу ничего просмотреть ...Кто-нибудь может понять, чего мне не хватает?

Мне кажется, я достаточно близок к достижению (возможно, я тоже неправ ...), поэтому любая помощь будет очень кстати!

Спасибо заранее!

...