In this write-up, I will be using open-source software’s to build a fully functional CI/CD pipeline that allows you to take code from a repository, build, commit, publish and deploy docker based images onto a Kubernetes 1.18 cluster – all by issuing in a git commit to your repository.
Building Sandbox (Developer Box)
Sandbox is a CentOS 7.3 based host, which serves applications you need in the CI/CD pipeline.
Software Available on the Sandbox:
· Gnome Desktop
· Docker Daemon and Engine
· git tools
· pyenv
· Python 2.7
· pip
· virtualenv
· drone command line tool
· PyCharm (Community)
· node version manager (nvm)
· node v6.9.2 (LTS)
CI/CD Pipeline workflow
data:image/s3,"s3://crabby-images/19f91/19f91130ebe729af273742c06acdc074dbceb564" alt=""
Gogs - Self-Hosted Git Service (https://gogs.io/)
Drone - Continuous Delivery System (https://www.drone.io/)
Kubernetes – Container Management Platform (https://kubernetes.io/)
In this CI/CD environment the developer can:
1. Store, commit and manage your code in Gogs
2. Automatically build a docker container from a code repository, using Drone
3. Automatically store that container on Docker Registry, using Drone
4. Automatically deploy the container to a Kubernetes pod!
Gogs:
Gogs is a private source code control system anyone can deploy locally, written in Go. I use it as a public GitHub alternative here.
We can create, manage and commit our code exactly as we would with GitHub. With this CI/CD Pipeline, we can then quickly see our code built into a container and deployed automatically onto Kubernetes by Drone.
Drone:
Drone is a CI/CD tool, which can pull our code from Gogs and build/publish/deploy it to Kubernetes nodes or other targets.
For Drone to be able to know how to execute a CI/CD pipeline for us, it uses three main stages:
Build - Builds your code from a repo kept in a store like Gogs
Publish - Takes our code, builds it into a container, and pushes it to a container repo like Docker Hub
Deploy - Deploys the container from the repo to the target platform - e.g., Kubernetes.
There are many other options here, but these are the main items.
Drone expects these stages to be built into a .yml file.
pipeline:
publish:
image: plugins/docker
dockerfile: Dockerfile
repo: drone:5000/busybox-sandeep
registry: drone:5000
insecure: true
tags: "${DRONE_BUILD_NUMBER}"
deploy:
image: devnetsandbox/kube
kubernetes_server: http://master:8001
kubernetes_token: <Your Kubernetes Token>
namespace: default
deployment: application1
container: busybox-sandeep
repo: drone:5000/ busybox-sandeep
registry: drone:5000
insecure: true
tag: "${DRONE_BUILD_NUMBER}"
Create Docker File in the repository
data:image/s3,"s3://crabby-images/4bc1d/4bc1db9e53372d2d42b7b94d2c722eaef9ddf6ce" alt=""
Upload the .yml file to your Git Repository
data:image/s3,"s3://crabby-images/2dc58/2dc585d011d401aaf9565678d3462233a0454903" alt=""
Git Clone the Repository
data:image/s3,"s3://crabby-images/f6611/f661181708b4aedfbbd906534378077b7a7664c7" alt=""
Once the commit is done – The Webhook will auto-sync and runs the pipeline.
data:image/s3,"s3://crabby-images/e942f/e942fd5b211eb461c6df76555b26ec7e5794ebed" alt=""
Deployment in Progress
data:image/s3,"s3://crabby-images/b1f2f/b1f2feac0fbb585e6c617bf453ab8a172db91245" alt=""
data:image/s3,"s3://crabby-images/86248/862484844c2c5e179bcb067be3f9c375b78ae320" alt=""
Deployment Completed
data:image/s3,"s3://crabby-images/82140/82140225ff04b6b4596949abc1ee16129b8a8d93" alt=""
Kubernetes Deployment
data:image/s3,"s3://crabby-images/fe7f7/fe7f7d7469b27be2370a16411301ef2a09651bc1" alt=""
data:image/s3,"s3://crabby-images/15c0a/15c0ac64b09a5b9528d9965a06fa72523a60c9c2" alt=""
kubectl describe pod - to get the deployment IP
data:image/s3,"s3://crabby-images/933c2/933c2f1afadef2145292fa01b26b994030f2e24a" alt=""