v0.0.1 #1
@@ -1,33 +1,36 @@
|
|||||||
name: Docker Image CI
|
name: Docker Image CI
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- dev
|
- dev
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: gitea-official-runner
|
runs-on: gitea-runner-group-candlelight
|
||||||
container:
|
container:
|
||||||
image: harbor.merlin.xin/testing/merlin/action_builder:471389b69e23417ab4e86981d109c79635d7219b
|
image: registry.merlin.xin/candlelight/action_builder:v0.0.1
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: docker login
|
- name: docker login
|
||||||
env:
|
env:
|
||||||
HARBOR_USERNAME: ${{ secrets.HARBOR_ROBOT }}
|
HARBOR_USERNAME: ${{ secrets.HARBOR_ROBOT }}
|
||||||
HARBOR_PASSWORD: ${{ secrets.HARBOR_ROBOT_SECRET }}
|
HARBOR_PASSWORD: ${{ secrets.HARBOR_ROBOT_SECRET }}
|
||||||
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
||||||
run: docker login ${HARBOR_URL} -u ${HARBOR_USERNAME} -p ${HARBOR_PASSWORD}
|
run: docker login ${HARBOR_URL} -u ${HARBOR_USERNAME} -p ${HARBOR_PASSWORD}
|
||||||
- name: Build and push Docker images
|
- name: Build and push Docker images
|
||||||
env:
|
env:
|
||||||
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
||||||
TAG: ${{ github.sha }}
|
TAG: ${{ github.sha }}
|
||||||
REPOSITORY: ${{ github.repository }}
|
REPOSITORY: ${{ github.repository }}
|
||||||
run: |
|
run: |
|
||||||
ROOT_DIR=$(pwd)
|
ROOT_DIR=$(pwd)
|
||||||
IMAGE_NAME="${HARBOR_URL}/testing/$REPOSITORY:${TAG}"
|
IMAGE_NAME="${HARBOR_URL}/testing/$REPOSITORY:${TAG}"
|
||||||
echo "Building image: ${IMAGE_NAME}"
|
echo "Building image: ${IMAGE_NAME}"
|
||||||
docker build -t ${IMAGE_NAME} .
|
docker build -t ${IMAGE_NAME} .
|
||||||
echo "Pushing image: ${IMAGE_NAME}"
|
echo "Pushing image: ${IMAGE_NAME}"
|
||||||
docker push ${IMAGE_NAME}
|
docker push ${IMAGE_NAME}
|
||||||
echo "Successfully pushed: ${IMAGE_NAME}"
|
echo "Successfully pushed: ${IMAGE_NAME}"
|
||||||
|
docker rmi ${IMAGE_NAME}
|
||||||
|
echo "cleaned up local image"
|
||||||
|
|
||||||
|
|||||||
@@ -1,32 +1,34 @@
|
|||||||
name: Docker Image CI
|
name: Docker Image CI
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
tags:
|
tags:
|
||||||
- '*'
|
- '*'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: gitea-official-runner
|
runs-on: gitea-runner-group-candlelight
|
||||||
container:
|
container:
|
||||||
image: harbor.merlin.xin/testing/merlin/action_builder:471389b69e23417ab4e86981d109c79635d7219b
|
image: registry.merlin.xin/candlelight/action_builder:v0.0.1
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: docker login
|
- name: docker login
|
||||||
env:
|
env:
|
||||||
HARBOR_USERNAME: ${{ secrets.HARBOR_ROBOT }}
|
HARBOR_USERNAME: ${{ secrets.HARBOR_ROBOT }}
|
||||||
HARBOR_PASSWORD: ${{ secrets.HARBOR_ROBOT_SECRET }}
|
HARBOR_PASSWORD: ${{ secrets.HARBOR_ROBOT_SECRET }}
|
||||||
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
||||||
run: docker login ${HARBOR_URL} -u ${HARBOR_USERNAME} -p ${HARBOR_PASSWORD}
|
run: docker login ${HARBOR_URL} -u ${HARBOR_USERNAME} -p ${HARBOR_PASSWORD}
|
||||||
- name: Build and push Docker images
|
- name: Build and push Docker images
|
||||||
env:
|
env:
|
||||||
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
HARBOR_URL: ${{ vars.HARBOR_URL }}
|
||||||
REPOSITORY: ${{ github.repository }}
|
REPOSITORY: ${{ github.repository }}
|
||||||
run: |
|
run: |
|
||||||
ROOT_DIR=$(pwd)
|
ROOT_DIR=$(pwd)
|
||||||
IMAGE_NAME="${HARBOR_URL}/release/$REPOSITORY:$GITHUB_REF_NAME"
|
IMAGE_NAME="${HARBOR_URL}/$REPOSITORY:$GITHUB_REF_NAME"
|
||||||
echo "Building image: ${IMAGE_NAME}"
|
echo "Building image: ${IMAGE_NAME}"
|
||||||
docker build -t ${IMAGE_NAME} .
|
docker build -t ${IMAGE_NAME} .
|
||||||
echo "Pushing image: ${IMAGE_NAME}"
|
echo "Pushing image: ${IMAGE_NAME}"
|
||||||
docker push ${IMAGE_NAME}
|
docker push ${IMAGE_NAME}
|
||||||
echo "Successfully pushed: ${IMAGE_NAME}"
|
echo "Successfully pushed: ${IMAGE_NAME}"
|
||||||
|
docker rmi ${IMAGE_NAME}
|
||||||
|
echo "cleaned up local image"
|
||||||
|
|||||||
20
Dockerfile
20
Dockerfile
@@ -1,8 +1,14 @@
|
|||||||
FROM harbor.merlin.xin/mirrors/docker.io/library/docker:24.0.6-dind
|
FROM registry.merlin.xin/library/docker:24.0.6-dind
|
||||||
|
|
||||||
# 安装 Node.js
|
# 安装 Node.js
|
||||||
RUN apk add --no-cache bash curl git nodejs npm
|
RUN apk add --no-cache bash curl git nodejs npm
|
||||||
|
|
||||||
WORKDIR /workspace
|
# 安装 helm CLI
|
||||||
|
RUN curl -fsSL https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz -o helm.tar.gz \
|
||||||
|
&& tar -zxvf helm.tar.gz \
|
||||||
|
&& mv linux-amd64/helm /usr/local/bin/helm \
|
||||||
|
&& rm -rf linux-amd64 helm.tar.gz
|
||||||
|
|
||||||
|
WORKDIR /workspace
|
||||||
|
|
||||||
ENTRYPOINT [ "/bin/bash" ]
|
ENTRYPOINT [ "/bin/bash" ]
|
||||||
Reference in New Issue
Block a user