fix: use kaniko for forgejo image builds
Some checks failed
build-and-push / build (push) Failing after 14s
Some checks failed
build-and-push / build (push) Failing after 14s
This commit is contained in:
parent
46b486fb52
commit
494384e6c6
2 changed files with 21 additions and 59 deletions
13
.forgejo/scripts/kaniko-build.sh
Executable file
13
.forgejo/scripts/kaniko-build.sh
Executable file
|
|
@ -0,0 +1,13 @@
|
|||
#!/busybox/sh
|
||||
set -eu
|
||||
|
||||
mkdir -p /kaniko/.docker
|
||||
cat > /kaniko/.docker/config.json <<JSON
|
||||
{"auths":{"${REGISTRY_HOSTPORT}":{"username":"${REGISTRY_USERNAME}","password":"${REGISTRY_PASSWORD}"}}}
|
||||
JSON
|
||||
|
||||
/kaniko/executor \
|
||||
--context "${GITHUB_WORKSPACE}" \
|
||||
--dockerfile "${GITHUB_WORKSPACE}/Dockerfile" \
|
||||
--destination "${REGISTRY_HOSTPORT}/${IMAGE_NAME}:${COMMIT_SHA}" \
|
||||
--destination "${REGISTRY_HOSTPORT}/${IMAGE_NAME}:${LATEST_TAG}"
|
||||
|
|
@ -9,73 +9,22 @@ on:
|
|||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-latest
|
||||
env:
|
||||
DOCKER_HOST: tcp://docker:2375
|
||||
DOCKER_TLS_CERTDIR: ""
|
||||
services:
|
||||
docker:
|
||||
image: docker:27-dind
|
||||
env:
|
||||
DOCKER_TLS_CERTDIR: ""
|
||||
options: --privileged
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Install Docker CLI
|
||||
run: |
|
||||
apt-get update
|
||||
apt-get install -y docker.io
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
run: |
|
||||
export DOCKER_HOST=tcp://docker:2375
|
||||
docker version
|
||||
docker buildx create --use || true
|
||||
docker buildx inspect --bootstrap
|
||||
|
||||
- name: Login to Registry
|
||||
- name: Build and push
|
||||
uses: docker://gcr.io/kaniko-project/executor:v1.23.2-debug
|
||||
env:
|
||||
REGISTRY_HOSTPORT: ${{ secrets.REGISTRY_HOSTPORT }}
|
||||
REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
|
||||
REGISTRY_PASSWORD: ${{ secrets.REGISTRY_PASSWORD }}
|
||||
run: |
|
||||
set -euo pipefail
|
||||
export DOCKER_HOST=tcp://docker:2375
|
||||
SHA="$(git rev-parse HEAD)"
|
||||
test -n "$REGISTRY_HOSTPORT"
|
||||
echo "$REGISTRY_PASSWORD" | docker login "$REGISTRY_HOSTPORT" -u "$REGISTRY_USERNAME" --password-stdin
|
||||
|
||||
- name: Build and push
|
||||
env:
|
||||
REGISTRY_HOSTPORT: ${{ secrets.REGISTRY_HOSTPORT }}
|
||||
run: |
|
||||
set -euo pipefail
|
||||
export DOCKER_HOST=tcp://docker:2375
|
||||
SHA="$(git rev-parse HEAD)"
|
||||
|
||||
build_and_push() {
|
||||
docker buildx build --push \
|
||||
-f Dockerfile \
|
||||
-t "$REGISTRY_HOSTPORT/nxtgauge-frontend-solid:${SHA}" \
|
||||
-t "$REGISTRY_HOSTPORT/nxtgauge-frontend-solid:high-performance-latest" \
|
||||
.
|
||||
}
|
||||
|
||||
for attempt in 1 2 3; do
|
||||
echo "Build attempt $attempt"
|
||||
if build_and_push; then
|
||||
exit 0
|
||||
fi
|
||||
echo "Build attempt $attempt failed; recreating builder and retrying"
|
||||
docker buildx rm --all-inactive --force || true
|
||||
docker buildx create --use || true
|
||||
docker buildx inspect --bootstrap
|
||||
sleep $((attempt * 10))
|
||||
done
|
||||
|
||||
echo "Build failed after retries"
|
||||
exit 1
|
||||
IMAGE_NAME: nxtgauge-frontend-solid
|
||||
LATEST_TAG: high-performance-latest
|
||||
COMMIT_SHA: ${{ github.sha }}
|
||||
with:
|
||||
entrypoint: /busybox/sh
|
||||
args: ${{ github.workspace }}/.forgejo/scripts/kaniko-build.sh
|
||||
|
||||
- name: Prune old image tags (keep latest 1 SHA)
|
||||
if: success()
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue