Gitlab CI: failing pipeline after switching from shared to dedicated runner?

Hello everyone,

Since I exceeded the Gitlab shared runner limit, I decided to make my own runner, hosted on DigitalOcean. I guess I followed the rules, but now every pipeline fails with a The command '/bin/sh -c docker/potential_asset_precompile.sh $PRECOMPILEASSETS' returned a non-zero code: 1

Obvioulsy on my local machine everything works just fine, and with this error I can’t find out how to fix this… Could anybody help me, please ? Thx in advance!

Prevous .gitlab-ci.yml (working with shared runner)

image: docker
services:
  - docker:dind

cache:
  paths:
    - node_modules

variables:
  CONTAINER_CURRENT_IMAGE: registry.gitlab.com/soykje/beweeg-ror:$CI_COMMIT_REF_SLUG
  CONTAINER_LATEST_IMAGE: registry.gitlab.com/soykje/beweeg-ror:latest
  CONTAINER_STABLE_IMAGE: registry.gitlab.com/soykje/beweeg-ror:stable

stages:
  - test
  - build
  - release
  - deploy

before_script:
  - docker login -u gitlab-ci-token -p $CI_BUILD_TOKEN registry.gitlab.com
  - 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
    # - docker-compose run app docker/wait_for_it.sh db:5433 --  "rake db:create db:migrate"
    # 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 . --pull -t $CONTAINER_CURRENT_IMAGE
    - 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 ./docker-compose.staging2.yml root@${DEPLOYMENT_SERVER_IP}:~/
    - ssh root@$DEPLOYMENT_SERVER_IP "docker login -u gitlab-ci-token -p ${CI_BUILD_TOKEN} registry.gitlab.com;
      docker-compose -f docker-compose.staging2.yml down;
      docker pull $CONTAINER_STABLE_IMAGE;
      docker-compose -f docker-compose.staging2.yml up -d"

Current .gitlab-ci.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"

And my runner config.toml (based on a DO Docker droplet, with 1GB memory)

concurrent = 1
check_interval = 0

[session_server]
  session_timeout = 1800

[[runners]]
  name = "beweeg-gitlab-runner"
  url = "https://gitlab.com/"
  token = "d2xaUTmhUiV-1fLPE_WZ"
  executor = "docker"
  [runners.custom_build_dir]
  [runners.docker]
    tls_verify = false
    image = "docker:stable"
    privileged = true
    disable_entrypoint_overwrite = false
    oom_kill_disable = false
    disable_cache = false
    volumes = ["/cache"]
    shm_size = 0
  [runners.cache]
    [runners.cache.s3]
    [runners.cache.gcs]

Of course if more information is needed please tell me… I’m quite stuck here, so I’ll be glad to debug this with your help!

Thx again