Update .gitea/workflows/k3s.yaml
This commit is contained in:
parent
157447e78a
commit
090ce1f578
@ -0,0 +1,80 @@
|
|||||||
|
name: k3s
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ "main" ]
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install kubectl
|
||||||
|
env:
|
||||||
|
K3S_TOKEN: ${{ secrets.K3S_TOKEN }}
|
||||||
|
K3S_CERT: ${{ secrets.K3S_CERT }}
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
# Fetch the latest stable version of kubectl
|
||||||
|
KUBECTL_VERSION=$(curl -s https://dl.k8s.io/release/stable.txt)
|
||||||
|
if [ -z "$KUBECTL_VERSION" ]; then
|
||||||
|
echo "Failed to fetch the latest kubectl version. Exiting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Download kubectl binary
|
||||||
|
curl -LO "https://dl.k8s.io/release/v1.31.0/bin/linux/amd64/kubectl"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "Failed to download kubectl binary. Exiting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Make kubectl executable and move to PATH
|
||||||
|
chmod +x kubectl
|
||||||
|
sudo mv kubectl /usr/local/bin/
|
||||||
|
|
||||||
|
# Verify kubectl installation
|
||||||
|
kubectl version --client
|
||||||
|
|
||||||
|
# Install kubelogin
|
||||||
|
curl -fsSLO https://github.com/int128/kubelogin/releases/download/v1.25.4/kubelogin_linux_amd64.zip
|
||||||
|
unzip kubelogin_linux_amd64.zip kubelogin -d kubelogin
|
||||||
|
mv kubelogin/kubelogin kubelogin/kubectl-oidc_login
|
||||||
|
export PATH=$PATH:$(realpath kubelogin)
|
||||||
|
|
||||||
|
# Create the kubeconfig file with the K3S_TOKEN and K3S_CERT
|
||||||
|
mkdir -p ~/.kube
|
||||||
|
|
||||||
|
# Base64 decode the K3S_CERT and write it to a file
|
||||||
|
echo "$K3S_CERT" | base64 --decode > ~/.kube/ca.crt
|
||||||
|
|
||||||
|
# Create the kubeconfig file
|
||||||
|
cat <<EOF > ~/.kube/config
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Config
|
||||||
|
clusters:
|
||||||
|
- name: k3s-cluster
|
||||||
|
cluster:
|
||||||
|
certificate-authority: ~/.kube/ca.crt
|
||||||
|
server: https://kubernetes.default.svc:6443
|
||||||
|
users:
|
||||||
|
- name: k3s-user
|
||||||
|
user:
|
||||||
|
token: $K3S_TOKEN
|
||||||
|
contexts:
|
||||||
|
- name: k3s-context
|
||||||
|
context:
|
||||||
|
cluster: k3s-cluster
|
||||||
|
user: k3s-user
|
||||||
|
current-context: k3s-context
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Test the kubeconfig setup by printing the cluster info
|
||||||
|
kubectl cluster-info
|
||||||
|
|
||||||
|
# Apply Kubernetes configuration
|
||||||
|
kubectl delete -f kubernetes.yaml
|
||||||
|
kubectl apply -f kubernetes.yaml
|
||||||
Loading…
Reference in New Issue
Block a user