diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 123e25cd3..f8d54c031 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -7,7 +7,34 @@ on: - "dev" jobs: - build: + build-base: + if: github.repository_owner == 'OpenAccess-AI-Collective' + runs-on: self-hosted + steps: + - name: Checkout + uses: actions/checkout@v3 + - name: Docker metadata + id: metadata + uses: docker/metadata-action@v3 + with: + images: winglian/axolotl-base + - name: Login to Docker Hub + uses: docker/login-action@v2 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + - name: Build + uses: docker/build-push-action@v4 + with: + context: . + file: ./docker/Dockerfile-base + push: ${{ github.event_name != 'pull_request' }} + tags: ${{ steps.metadata.outputs.tags }} + labels: ${{ steps.metadata.outputs.labels }} + build-axolotl: + needs: build-base if: github.repository_owner == 'OpenAccess-AI-Collective' runs-on: self-hosted steps: @@ -29,7 +56,7 @@ jobs: uses: docker/build-push-action@v4 with: context: . - file: ./Dockerfile + file: ./docker/Dockerfile push: ${{ github.event_name != 'pull_request' }} tags: ${{ steps.metadata.outputs.tags }} labels: ${{ steps.metadata.outputs.labels }} diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml deleted file mode 100644 index 9cb5e0f10..000000000 --- a/.gitlab-ci.yml +++ /dev/null @@ -1,14 +0,0 @@ -image: "python:3.7" - -build: - stage: build - image: - name: gcr.io/kaniko-project/executor:v1.9.0-debug - entrypoint: [""] - script: - - /kaniko/executor - --context "${CI_PROJECT_DIR}" - --dockerfile "${CI_PROJECT_DIR}/Dockerfile" - --no-push - rules: - - if: $CI_COMMIT_SHA diff --git a/Dockerfile b/docker/Dockerfile similarity index 100% rename from Dockerfile rename to docker/Dockerfile diff --git a/docker/Dockerfile-base b/docker/Dockerfile-base new file mode 100644 index 000000000..f50c7f734 --- /dev/null +++ b/docker/Dockerfile-base @@ -0,0 +1,25 @@ +ARG CUDA_VERSION="11.8.0" +ARG CUDNN_VERSION="8" +ARG UBUNTU_VERSION="22.04" + +FROM nvidia/cuda:$CUDA_VERSION-cudnn$CUDNN_VERSION-devel-ubuntu$UBUNTU_VERSION + +ENV PATH="/root/miniconda3/bin:${PATH}" + +ARG PYTHON_VERSION="3.9" +ENV PYTHON_VERSION=$PYTHON_VERSION + +RUN apt-get update +RUN apt-get install -y wget && rm -rf /var/lib/apt/lists/* + +RUN wget \ + https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh \ + && mkdir /root/.conda \ + && bash Miniconda3-latest-Linux-x86_64.sh -b \ + && rm -f Miniconda3-latest-Linux-x86_64.sh + +RUN conda create -n "py${PYTHON_VERSION}" python="${PYTHON_VERSION}" + +ENV PATH="/root/miniconda3/envs/py${PYTHON_VERSION}/bin:${PATH}" + +WORKDIR /workspace