Czy uruchomienie kompilatora dokującego nie jest obsługiwane w BitBucket?


12

Cel

Celem jest uruchomienie kompilowania dokerów w potokach BitBucket

Próba

bitbucket-pipelines.yml

image: docker/compose:1.12.0

pipelines:
  default:
    - step:
        script:
          - docker-compose up --build

Wynik

The Docker Engine version is less than the minimum required by Compose.
Your current project requires a Docker Engine of version 1.13.0 or greater.

Dyskusja

Zgodnie z tym postem nie jest obsługiwany?

Odpowiedzi:


10

Oto moje rozwiązanie: (bitbucket-pipelines.yml)

pipelines:
  default:
    - step:
        script:
          - export DOCKER_COMPOSE_VERSION=1.18.0
          - export DOCKER_COMPOSE_URL=https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-$(uname -s)-$(uname -m)
          - curl -L $DOCKER_COMPOSE_URL > docker-compose
          - chmod +x docker-compose
          - mv docker-compose /usr/local/bin
          - docker-compose build --force-rm --no-cache --pull

6

Mniej prawdopodobne jest, że zobaczymy natywną integrację z kompozycją dokerów, ponieważ API potoków jest niestandardową implementacją podobnej funkcjonalności, a także z powodu możliwych problemów bezpieczeństwa, ale wygląda na to, że obecnie opracowywanych jest więcej funkcji w celu implementacji większej liczby funkcji podobnych do dokerów w ten otwarty problem.

AKTUALIZACJA: dodano obsługę rurociągów wielokontenerowych, jak opisano w dokumentacji


3

Udało mi się użyć komponentu dokującego do wypychania obrazów do zdalnego hosta za pomocą następującego obrazu.

tmaier / docker-compose: najnowszy

Jest to podstawowy obraz dokera z zainstalowanym programem dokowania-tworzenia.

Mój bitbucket-pipelines.ymlwygląda tak:

- step:
    image: tmaier/docker-compose:latest
    script:
        - (umask  077 ; echo $DOCKER_PRIVATE_KEY | base64 -d > ./keys/key.pem)
        - export DOCKER_CERT_PATH=./keys/
        - export DOCKER_TLS_VERIFY="1"
        - export DOCKER_HOST=tcp://<DOCKER_HOST_IP>:2376
        - docker login --username $DOCKER_HUB_USERNAME --password $DOCKER_HUB_PASSWORD
        - docker-compose up -d <service>

Zalogowałem się w moim repozytorium ca.pemi jest to cert.pempotrzebne dla docker-compose w keyskatalogu. Klucz prywatny jest zapisywany zakodowany base64, jako bezpieczna zmienna w zmiennych środowiskowych potoków Bitbucket, więc po prostu dekoduję go i wklejam keys/key.pemdo potoku jako pierwszy krok.

Należy pamiętać, że użyłem docker loginpo ustawieniu zmiennych środowiska dla zdalnego hosta.


0

bitbucket-pipelines.yml

image: python:3.8.1

pipelines:
  branches:
    "**":
      - step:
          name: Build
          services:
            - docker
          caches:
            - docker
            - pip
          script:
            - pip install docker-compose
            - docker network create dockernet
            - docker-compose build

definitions:
  services:
    docker:
      memory: 2048
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.