K8s Gitlab Integration
This page covers integrating GitLab with the Nautilus cluster to automatically deploy from GitLab to Kubernetes via CI/CD jobs.
In your project, go to
Operate -> Kubernetes clusters
, click the dropdown in the top right and selectConnect a cluster (certificate - deprecated)
In the namespace create a GitLab service account:
kubectl create sa gitlab -n <your_namespace>
Create the rolebinding for the service account:
kubectl create -f - << EOFapiVersion: rbac.authorization.k8s.io/v1kind: RoleBindingmetadata:name: gitlabnamespace: <your_namespace>roleRef:apiGroup: rbac.authorization.k8s.iokind: ClusterRolename: adminsubjects:- kind: ServiceAccountname: gitlabnamespace: <your_namespace>EOFCreate a secret for the service account:
kubectl -n <your_namespace> apply -f - << EOFapiVersion: v1kind: Secretmetadata:name: gitlab-secretannotations:kubernetes.io/service-account.name: gitlabtype: kubernetes.io/service-account-tokenEOFGet the secret and Certificate Authority (CA) for the service account:
kubectl get secret -n your_namespace | grep gitlab
kubectl get secret -n your_namespace <gitlab-secret-...> -o yaml
echo <the token value> | base64 -d
- this will give you the service token field valueecho <the CA value> | base64 -d
- CAAPI URL - get from your cluster config file (
https://67.58.53.147:6443
)Uncheck
GitLab-managed cluster
, enter the namespace intoProject namespace prefix (optional, unique)
Click
Add kubernetes cluster
Now your cluster config will be available to tools like kubectl
and helm
to access your namespace. You can use this project as an example of how to automatically deploy a Helm application to your namespace and this one to automatically update the deployment image.