In this post, i will guide you to install self-hosted github action runner, then setup a simple workflow to run some command on that runner. To setup github action self-hosted runner, we will use action-runner-controller. I will use minikube and create a private repository on github for demo purpose. The runner controller will use Personal Access Token to authenticate with Github API.
1. Create Personal Access Token (PAT).
Go to https://github.com/settings/tokens?type=beta and create a PAT with the following repository permission.
- Read access to discussions, issues, merge queues, metadata, repository hooks, and secrets
- Read and Write access to actions, administration, code, commit statuses, deployments, environments, pull requests, and workflows
data:image/s3,"s3://crabby-images/55bb0/55bb0e833b0036829bc713a6f3a77404f0ce7fd3" alt=""
2. Setup Action Runner Controller
For this part, we will use helm
and follow this instruction. Run the following command to install controller and their dependency.
2.1 Install cert-manager in your cluster
Add the Helm repository
helm repo add jetstack https://charts.jetstack.io
Update your local Helm chart repository cache:
helm repo update
Install cert-manager
helm install \
cert-manager jetstack/cert-manager \
--namespace cert-manager \
--create-namespace \
--version v1.11.0 \
--set installCRDs=true
data:image/s3,"s3://crabby-images/fc5bb/fc5bb1c04beacfbb8ced079312ed72b7d7e22c53" alt=""
2.2 Install Action Runner Controller
Add the helm repository
helm repo add actions-runner-controller https://actions-runner-controller.github.io/actions-runner-controller
Update local chart
helm repo update
Install controller, replace your PAT.
helm upgrade --install --namespace actions-runner-system --create-namespace\
--set=authSecret.create=true\
--set=authSecret.github_token="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"\
--wait actions-runner-controller actions-runner-controller/actions-runner-controller
data:image/s3,"s3://crabby-images/be0c4/be0c4117c533cf7b347ab406245cc384d6ae3602" alt=""
2.3 Create Runner Deployment
Create service account for runner. For demo purpose, i will create a service account and binding cluster admin role to this service account. The content of service-account.yaml
is same as below.
apiVersion: v1
kind: ServiceAccount
metadata:
namespace: default
name: github-runner-api-sa
automountServiceAccountToken: true
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: github-runner-api-cluster-role-binding
namespace: default
subjects:
- kind: ServiceAccount
name: github-runner-api-sa
namespace: default
apiGroup: ""
roleRef:
kind: ClusterRole
name: admin
apiGroup: rbac.authorization.k8s.io
kubectl create -f service-account.yaml
data:image/s3,"s3://crabby-images/bf25e/bf25ec0a29c92b235edc90d886650a6697191d94" alt=""
Create RunnerDeployment
resource. The content for runner.yaml
is same as below.
You need to modify repository
and labels
to match with your repository.
apiVersion: actions.summerwind.dev/v1alpha1
kind: RunnerDeployment
metadata:
name: github-runner-api
namespace: default
spec:
replicas: 1
template:
spec:
serviceAccountName: github-runner-api-sa
automountServiceAccountToken: true
image: summerwind/actions-runner-dind
dockerdWithinRunnerContainer: true
labels:
- k8s-api
repository: prjmpkcopper/k8s-runner-test
workVolumeClaimTemplate:
storageClassName: "standard"
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 5Gi
env: []
kubectl create -f runner.yaml
data:image/s3,"s3://crabby-images/b8e45/b8e45f6c0212af35a4a7e1e551bec1c1be1e74b0" alt=""
2.4 Check runner status
Run the below command to list and check status of this runner.
kubectl get runner
data:image/s3,"s3://crabby-images/c1faa/c1faad4118bb912ee2d313d8cdd6a6bb4f159b08" alt=""
After waiting for a while, you will see our self-hosted runner on GitHub. Our runner has k8s-api
label, we will use this in workflows.
data:image/s3,"s3://crabby-images/56429/56429916cc66f4d1ad0281a8d67393d6f4f67b23" alt=""
3. Setup demo workflows
I will create a simple workflows, we will have one job to list all pod on k8s cluster. The content is same as below.
name: Auto Build/Deploy
on:
push:
branches:
- "*"
jobs:
build:
name: Build
runs-on:
- self-hosted
- k8s-api
steps:
- name: Get Pods
run: |
set -ex
cd $HOME
wget https://dl.k8s.io/release/v1.26.0/bin/linux/arm64/kubectl
chmod +x ./kubectl
./kubectl auth can-i get pods
./kubectl get pods -A
Push code to Github and open action tab, you will see our runner is running.
data:image/s3,"s3://crabby-images/e9c62/e9c627b6c13cf70e52e7513e2bd600ddbc05ae64" alt=""
View the Build
job.
data:image/s3,"s3://crabby-images/6ddec/6ddec09c5b09e6ee3999286e57fbcc50de2ffdf8" alt=""
Check the get pods
step.
data:image/s3,"s3://crabby-images/7838d/7838dd44e6ecbbf0fea804037ca29c67e9d4d37d" alt=""
That is, we already able to create GitHub action self-hosted runner. Thank for reading.