208 lines
6.7 KiB
YAML
208 lines
6.7 KiB
YAML
name: Build Offline K3s Installer
|
|
|
|
on:
|
|
push:
|
|
paths:
|
|
- 'scripts/resolve_k3s_versions.sh'
|
|
- 'scripts/make_k3s_offline_package.sh'
|
|
- '.github/workflows/offline-package-k3s-installer.yaml'
|
|
workflow_dispatch:
|
|
|
|
env:
|
|
NERDCTL_VERSION: "2.1.4"
|
|
|
|
jobs:
|
|
build-k3s-installer:
|
|
strategy:
|
|
matrix:
|
|
arch: [amd64, arm64]
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
k3s_version: ${{ steps.resolve.outputs.version }}
|
|
|
|
steps:
|
|
- name: Checkout repo
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Prepare toolchain (curl/jq/tar/tree + nerdctl)
|
|
run: |
|
|
set -euo pipefail
|
|
sudo apt-get update
|
|
sudo apt-get install -y curl jq tar tree
|
|
|
|
NURL="https://github.com/containerd/nerdctl/releases/download/v${NERDCTL_VERSION}/nerdctl-${NERDCTL_VERSION}-linux-amd64.tar.gz"
|
|
TGZ="/tmp/nerdctl-${NERDCTL_VERSION}.tgz"
|
|
echo "Downloading: ${NURL}"
|
|
curl -fSL --retry 3 --retry-connrefused --connect-timeout 15 "${NURL}" -o "${TGZ}"
|
|
# 可选校验:如需严格校验,取消下面两行的注释
|
|
# curl -fSL "${NURL}.sha256" -o "${TGZ}.sha256"
|
|
# (cd /tmp && sha256sum -c "$(basename ${TGZ}).sha256") || { echo "SHA256 mismatch"; exit 1; }
|
|
|
|
sudo tar -C /usr/local/bin -xzf "${TGZ}"
|
|
sudo chmod +x /usr/local/bin/nerdctl
|
|
sudo nerdctl --version
|
|
|
|
- name: Resolve latest k3s version
|
|
id: resolve
|
|
run: |
|
|
set -euo pipefail
|
|
bash scripts/resolve_k3s_versions.sh
|
|
|
|
- name: Build offline package
|
|
env:
|
|
K3S_VERSION: ${{ steps.resolve.outputs.version }}
|
|
ARCH: ${{ matrix.arch }}
|
|
run: |
|
|
set -euo pipefail
|
|
chmod +x scripts/make_k3s_offline_package.sh
|
|
./scripts/make_k3s_offline_package.sh
|
|
|
|
- name: Validate airgap image tar
|
|
run: |
|
|
set -euo pipefail
|
|
TAR="k3s-offline-package/images/k3s-airgap-images-${{ matrix.arch }}.tar"
|
|
tmp=$(mktemp -d)
|
|
tar -xf "$TAR" -C "$tmp" manifest.json
|
|
configs=$(jq -r '.[].Config' "$tmp/manifest.json")
|
|
for cfg in $configs; do
|
|
tar -xf "$TAR" -C "$tmp" "$cfg"
|
|
arch=$(jq -r '.architecture' "$tmp/$cfg")
|
|
if [ "$arch" != "${{ matrix.arch }}" ]; then
|
|
echo "unexpected arch $arch in $cfg" >&2
|
|
exit 1
|
|
fi
|
|
done
|
|
rm -rf "$tmp"
|
|
|
|
- name: Pack final installer
|
|
run: |
|
|
set -euo pipefail
|
|
# 假设脚本产出目录为 k3s-offline-package
|
|
test -d k3s-offline-package
|
|
tar czf offline-package-k3s-installer-${{ matrix.arch }}.tar.gz k3s-offline-package
|
|
ls -lh offline-package-k3s-installer-${{ matrix.arch }}.tar.gz
|
|
|
|
- name: Upload artifact
|
|
uses: actions/upload-artifact@v4
|
|
with:
|
|
name: offline-package-k3s-installer-${{ matrix.arch }}
|
|
path: offline-package-k3s-installer-${{ matrix.arch }}.tar.gz
|
|
if-no-files-found: error
|
|
|
|
test-k3s-installer:
|
|
needs: build-k3s-installer
|
|
strategy:
|
|
matrix:
|
|
arch: [amd64, arm64]
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: Download Artifact
|
|
uses: actions/download-artifact@v4
|
|
with:
|
|
name: offline-package-k3s-installer-${{ matrix.arch }}
|
|
path: ./test-dir
|
|
|
|
- name: Extract Package
|
|
run: |
|
|
cd test-dir
|
|
tar -xzvf offline-package-k3s-installer-${{ matrix.arch }}.tar.gz
|
|
|
|
- name: Install jq
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get install -y jq
|
|
|
|
- name: Verify k3s binary arch
|
|
run: |
|
|
set -euo pipefail
|
|
BIN="test-dir/k3s-offline-package/bin/k3s-${{ matrix.arch }}"
|
|
file "$BIN"
|
|
if [ "${{ matrix.arch }}" = "amd64" ]; then
|
|
file "$BIN" | grep -q 'x86-64'
|
|
else
|
|
file "$BIN" | grep -q 'aarch64'
|
|
fi
|
|
|
|
- name: Verify image platforms
|
|
run: |
|
|
set -euo pipefail
|
|
TAR="test-dir/k3s-offline-package/images/k3s-airgap-images-${{ matrix.arch }}.tar"
|
|
tmp=$(mktemp -d)
|
|
tar -xf "$TAR" -C "$tmp" manifest.json
|
|
configs=$(jq -r '.[].Config' "$tmp/manifest.json")
|
|
for cfg in $configs; do
|
|
tar -xf "$TAR" -C "$tmp" "$cfg"
|
|
arch=$(jq -r '.architecture' "$tmp/$cfg")
|
|
if [ "$arch" != "${{ matrix.arch }}" ]; then
|
|
echo "unexpected arch $arch in $cfg" >&2
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
- name: Setup K3s and Test
|
|
if: matrix.arch == 'amd64'
|
|
run: |
|
|
cd test-dir/k3s-offline-package
|
|
bash install-server.sh
|
|
KUBECONFIG=/etc/rancher/k3s/k3s.yaml kubectl get nodes
|
|
KUBECONFIG=/etc/rancher/k3s/k3s.yaml kubectl get pods -A
|
|
|
|
publish-release:
|
|
needs: test-k3s-installer
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
TAG_NAME: ${{ github.event.inputs.tag != '' && github.event.inputs.tag || format('offline-k3s-{0}', github.run_number) }}
|
|
RSYNC_SSH_KEY: ${{ secrets.RSYNC_SSH_KEY }}
|
|
RSYNC_SSH_USER: ${{ secrets.RSYNC_SSH_USER }}
|
|
VPS_HOST: ${{ secrets.VPS_HOST }}
|
|
REMOTE_ROOT: /data/update-server/nginx-ingress
|
|
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Create GitHub Release
|
|
id: create_release
|
|
uses: actions/create-release@v1
|
|
with:
|
|
tag_name: ${{ env.TAG_NAME }}
|
|
release_name: Daily Build ${{ env.TAG_NAME }}
|
|
draft: false
|
|
prerelease: false
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Download amd64 Artifact
|
|
uses: actions/download-artifact@v4
|
|
with:
|
|
name: offline-package-k3s-installer-amd64
|
|
path: release-artifacts
|
|
|
|
- name: Download arm64 Artifact
|
|
uses: actions/download-artifact@v4
|
|
with:
|
|
name: offline-package-k3s-installer-arm64
|
|
path: release-artifacts
|
|
|
|
- name: Upload to GitHub Release
|
|
uses: softprops/action-gh-release@v1
|
|
with:
|
|
tag_name: ${{ env.TAG_NAME }}
|
|
files: |
|
|
release-artifacts/offline-package-k3s-installer-amd64.tar.gz
|
|
release-artifacts/offline-package-k3s-installer-arm64.tar.gz
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Prune old releases (keep last 3)
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
run: |
|
|
set -euo pipefail
|
|
releases=$(gh release list --limit 100 --json tagName,createdAt --jq 'sort_by(.createdAt) | reverse | .[3:] | .[].tagName')
|
|
if [[ -n "$releases" ]]; then
|
|
for tag in $releases; do
|
|
gh release delete "$tag" -y
|
|
done
|
|
fi
|