Read this in other languages: 한국어、中国 .
This project shows how a common multi-component workload, in this case GitLab, can be deployed on Kubernetes Cluster. GitLab is famous for its Git-based and code-tracking tool. GitLab represents a typical multi-tier app and each component will have their own container(s). The microservice containers will be for the web tier, the state/job database with Redis and PostgreSQL as the database.
By using different GitLab components (NGINX, Ruby on Rails, Redis, PostgreSQL, and more), you can deploy it to Kubernetes. This example is also deployable using Databases for PostgreSQL in IBM Cloud as the database.
-
The user interacts with GitLab via the web interface or by pushing code to a GitHub repository. The GitLab container runs the main Ruby on Rails application behind NGINX and gitlab-workhorse, which is a reverse proxy for large HTTP requests like file downloads and Git push/pull. While serving repositories over HTTP/HTTPS, GitLab utilizes the GitLab API to resolve authorization and access and serves Git objects.
-
After authentication and authorization, the GitLab Rails application puts the incoming jobs, job information, and metadata on the Redis job queue that acts as a non-persistent database.
-
Repositories are created in a local file system.
-
The user creates users, roles, merge requests, groups, and more—all are then stored in PostgreSQL.
-
The user accesses the repository by going through the Git shell.
Create a Kubernetes cluster with either Minikube for local testing, or with IBM Cloud Kubernetes Service to deploy in cloud. The code here is regularly tested against Kubernetes Cluster from IBM Cloud Kubernetes Service using Travis.
Helm to install GitLab's Cloud Native charts.
- Clone the repo
- Create IBM Cloud Kubernetes Service
- Install Helm
- Configure GitLab and Install
- Launch GitLab
Clone the repo and go in the cloned directory
$ git clone https://github.com/IBM/Kubernetes-container-service-GitLab-sample/
Create an IBM Cloud Kubernetes Service if you don't already have one:
If you don't have the Helm client in your machine, you can find one in the official releases page.
To install Helm in your Kubernetes Cluster, do:
$ helm init
Add the official gitlab repo:
$ helm repo add gitlab https://charts.gitlab.io/
$ helm repo update
To verify installation of Helm in your cluster:
$ helm version
Client: &version.Version{SemVer:"v2.11.0", GitCommit:"2e55dbe1fdb5fdb96b75ff144a339489417b146b", GitTreeState:"clean"}
Server: &version.Version{SemVer:"v2.11.0", GitCommit:"2e55dbe1fdb5fdb96b75ff144a339489417b146b", GitTreeState:"clean"}
For more info in installing helm, you can find the official documentation here. The helm version that you install should be the same version or a previous version to the version of the cluster (i.e. the Server version in
helm version
). If the helm version is newer than the cluster, the command may not work as expected.
You can find the official helm chart repo for Cloud Native GitLab deployment here. This can guide you in configuring your own deployment for production use.
A sample configuration config.yaml
in this repo can help you get started with GitLab in IKS. This yaml file is configured to use the provided ingress controller with IKS. The components (Gitaly, Postgres, Redis, Minio) will not use any persistent storage for now.
Modify config.yaml
file to use your own Ingress Subdomain, certificate, and IP.
$ bx cs cluster-get <CLUSTER_NAME>
## You should look for these values
## ...
## Ingress Subdomain: anthony-dev.us-south.containers.appdomain.cloud
## Ingress Secret: anthony-dev
## ...
To get the ALB (Application Load Balancer) IP address of your cluster:
$ bx cs albs --cluster <CLUSTER_NAME>
## Get the IP Address from the public ALB
## ALB ID Enabled Status Type ALB IP Zone
## private-...-alb1 false disabled private - -
## public-...-alb1 true enabled public 169.XX.XX.XX dal13
You can now fill in your own values of INGERSS_SUBDOMAIN
, INGRESS_SECRET
, and ALB_IP
in config.yaml
Install GitLab by doing:
$ helm upgrade --install gitlab gitlab/gitlab -f config.yaml
Installing GitLab can take minutes to setup. You can check the status of your deployment:
$ kubectl get pods
NAME READY STATUS RESTARTS AGE
gitlab-gitaly-0 1/1 Running 0 3m
gitlab-gitlab-runner-7554ff7c9d-2rt7x 0/1 Running 4 3m
gitlab-gitlab-shell-78b8677b59-9z9m2 1/1 Running 0 3m
gitlab-gitlab-shell-78b8677b59-hssqc 1/1 Running 0 2m
gitlab-migrations.1-74xqt 0/1 Completed 0 3m
gitlab-minio-7b67585cf5-tc4gh 1/1 Running 0 3m
gitlab-minio-create-buckets.1-bdbhk 0/1 Completed 0 3m
gitlab-postgresql-7756f9c75f-pzvlj 1/1 Running 0 3m
gitlab-redis-554dc46b4c-jlkps 2/2 Running 0 3m
gitlab-registry-75cdd8cc6d-n6fx6 1/1 Running 0 2m
gitlab-registry-75cdd8cc6d-nz9sq 1/1 Running 0 3m
gitlab-sidekiq-all-in-1-5865f7f999-wvg6c 1/1 Running 0 3m
gitlab-task-runner-d84b7b9b9-9mc9k 1/1 Running 0 3m
gitlab-unicorn-596cbf98cc-kqrsr 2/2 Running 0 3m
gitlab-unicorn-596cbf98cc-mjbtn 2/2 Running 0 2m
If all your pods are now running, you can now go to your GitLab installation by visiting https://gitlab.<INGRESS_SUBDOMAIN>
Now that Gitlab is running you can register as a new user and create a project.
To try GitLab with persistent storage, you can explore config-persistent.yaml
and use that instead of config.yaml
. This will use dynamic storage provisioning that's provided with IKS.
You can learn how to expose the port 22
here with the ingress controller to clone repositories using SSH.
If a pod doesn't start examine the logs.
kubectl get pods
kubectl logs <pod name>
To delete your GitLab installation:
$ helm delete gitlab --purge
This code pattern is licensed under the Apache Software License, Version 2. Separate third party code objects invoked within this code pattern are licensed by their respective providers pursuant to their own separate licenses. Contributions are subject to the Developer Certificate of Origin, Version 1.1 (“DCO”) and the Apache Software License, Version 2.
ASL FAQ link: http://www.apache.org/foundation/license-faq.html#WhatDoesItMEAN