Module 3: Deploying the Todo App with GitOps
Module Overview
This module focuses on deploying a Todo application using GitOps principles. Participants will learn how to set up a GitOps repository, define the desired state of the application, and use Argo CD for deployment. Additionally, they will explore Gitea as an alternative Git service and perform hands-on tasks to deploy the Todo app using GitOps.
Key Learning Objectives
-
Understand the GitOps workflow for application deployment.
-
Learn how to set up and manage a GitOps repository.
-
Use Argo CD for real-time synchronization and health monitoring.
-
Explore Gitea as a self-hosted Git service and its integration with Argo CD.
-
Deploy a Todo app using GitOps principles and observe automated deployment processes.
Setting up the GitOps Repository
Initializing the Git Repository
Below is an example of creating a repo to be used for GitOps. Follow these steps:
-
Create a new repository on your preferred Git hosting service (e.g., GitHub, GitLab).
-
Clone the repository to your local machine:
git clone <repository-url> cd <repository-name>
-
Initialize the GitOps structure by creating the following directories:
mkdir -p manifests/base manifests/overlays/production
-
Add the necessary Kubernetes manifests (e.g., deployment.yaml, service.yaml) to the
manifests/base
directory. -
Commit and push the changes to the repository:
git add . git commit -m "Initialize GitOps repository" git push origin main
GitOps-Compatible Structure
Ensure your repository follows a GitOps-compatible structure. This typically includes:
-
A
base
directory for common configurations. -
An
overlays
directory for environment-specific configurations (e.g., production, staging). -
Kubernetes manifests (YAML files) defining the desired state of the application.
Defining the Desired State
Key Resources
The desired state of the Todo application in Git. Key resources include:
-
Deployment: Specifies the desired state of the application pods.
-
Service: Exposes the application to the network.
-
ConfigMap/Secret: Stores configuration data and sensitive information.
-
Route: to be used for comminucation into the application.
Using Argo CD for Deployment
Synchronizing with Argo CD
When using Argo CD to synchronize the application deployment on OpenShift with the Git repository:
-
Install Argo CD on your OpenShift cluster.
-
Create an Argo CD application pointing to your Git repository:
argocd app create todo-app \ --repo <repository-url> \ --path manifests/overlays/production \ --dest-server https://kubernetes.default.svc \ --dest-namespace default
-
Sync the application to deploy it:
argocd app sync todo-app
Hands-On Task
Deploying the Todo App
Navigate to the Gitea Project
data:image/s3,"s3://crabby-images/45501/4550177f88b091d9b4872aabafb7009710eba9af" alt="20241121095820"
Access the Gita URL
data:image/s3,"s3://crabby-images/e3df2/e3df2f55a23e47bea57f1518dd177c26795e8b6e" alt="20241120132152"
Change the app-config/cluster-config.yaml
to your repo url
data:image/s3,"s3://crabby-images/5c578/5c578485ea3cda6f1cbeb8a06bd89ccc5f92e124" alt="20241121095717"
Change the app/kustomization.yaml
namespace to your namespace
namespace todo-demo-app-yourusername
|
spec→destination→namespace todo-demo-app-yourusername
|
spec→project yourusername-project
|
data:image/s3,"s3://crabby-images/7f292/7f292907926a2d7d8c570f248b224284dd12670a" alt="20241121105934"
Login into the ArgoCD instance
Located under openshift-gitops → Routes Menu Click on openshift-gitops-server
Location
Click on LOG IN VIA OPENSHIFT
|
data:image/s3,"s3://crabby-images/1f2e6/1f2e6ded403848164862e8693af4d771f2c2478e" alt="20241121095839"
Use your OpenShift username and password to access cluster and Authorize Access
data:image/s3,"s3://crabby-images/329ab/329ab9d2c7379d57b39c3a713d6e1beb628d6ac9" alt="20241121095857"
Configure your Repo under Settings→Repositories
Enter the vaules below |
-
Type
git
-
Project
yourusername-project
-
Repository URL
https://gitea-gitea.apps.ocp4.example.com/yourusername/todo-demo-app-helmrepo.git
-
Username (optional)
user1
-
Password (optional)
Validate the connection was Successful
data:image/s3,"s3://crabby-images/c49f1/c49f1de32225b0e56dec6fe0bdb475ca80155dd5" alt="20241121095924"
Copy the configuration from your Gitea Repo into ArgoCD
data:image/s3,"s3://crabby-images/5c578/5c578485ea3cda6f1cbeb8a06bd89ccc5f92e124" alt="20241121095717"
Click on the EDIT AS YAML
data:image/s3,"s3://crabby-images/19fa1/19fa1ffc4a2644ea15d279a84d50d945793e1a90" alt="20241121115305"
Save the yaml configuration in ArgoCD
data:image/s3,"s3://crabby-images/5ee75/5ee7557847cafa78a1ca01f118200dec82952c35" alt="20241121100106"
Click Create to start deployment
data:image/s3,"s3://crabby-images/c23a7/c23a725e9a89d740976d4b3b26876f1c8727ff42" alt="20241121100117"
Validate ArgoCD Sync status
data:image/s3,"s3://crabby-images/9a403/9a40315fefb703460a9512ba108b7f6533e32261" alt="20241121105811"
Navigate to your todo-demo-app-yourusername namespace and select route
data:image/s3,"s3://crabby-images/95954/959540fb7b8c15427e23c3f1036012a298c47fe7" alt="20241121105841"
View deployed application
data:image/s3,"s3://crabby-images/5a1d4/5a1d4df11dbdf8a388f855263c4fedcb8fe63ce6" alt="20241121105910"
Module Summary
Key takeaways from this module include:
-
Understanding the GitOps workflow for application deployment.
-
Setting up and managing a GitOps repository.
-
Using Argo CD for real-time synchronization and health monitoring.
-
Exploring Gitea as a self-hosted Git service and its integration with Argo CD.
-
Deploying a Todo app using GitOps principles and observing automated deployment processes.