-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
2468253
commit 095ced8
Showing
2 changed files
with
92 additions
and
78 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,85 +1,99 @@ | ||
--- | ||
slug: lab-10 | ||
title: BYO manifests to create a workload | ||
sidebar_label: BYO manifests | ||
slug: deploy-workloads-argo-cd-otomi-kubernetes | ||
title: Deploy Workloads with Argo CD | ||
sidebar_label: Deploy Workloads with Argo CD | ||
description: Learn how to deploy your applications using Argo CD in the Otomi Kubernetes environment with this comprehensive guide. Discover how to manage resources effectively using Git and streamline your deployment process. | ||
keywords: | ||
- Argo | ||
- ArgoCD | ||
- Otomi | ||
- Kubernetes | ||
- GitOps | ||
- Workloads | ||
- Deployment | ||
- Deploying | ||
- HowTo | ||
- Tutorial | ||
--- | ||
|
||
:::info | ||
Argo CD needs to be activated for this lab. | ||
**Prerequisite**: Argo CD needs to be activated for this lab. | ||
::: | ||
|
||
Deploying your applications by doing `kubectl apply -f` is not ideal. As a developer you would like to manage resources based on code stored in Git. Otomi integrates Argo CD to provide an out-of-the-box GitOps solution. | ||
|
||
## Using Argo CD to deploy manifests and charts | ||
|
||
In the apps section in Otomi console, you'll see an app called Argo CD. Click on it. | ||
|
||
data:image/s3,"s3://crabby-images/17ad0/17ad05268f2bbbe581985e9293316e7a99a1aac0" alt="kubecfg" | ||
|
||
In Argo CD you'll see that an Argo app has already been created for your team. This app is configured to synchronize any manifest that is in the created repo in Gitea for Argo. | ||
|
||
data:image/s3,"s3://crabby-images/b76f6/b76f65b57ac72a51c1304df04cc8e53261815a6e" alt="kubecfg" | ||
|
||
If you click on the app and then click on `APP DETAILS`, you'll see the `REPO URL` and also that the `SYNC POLICY` is set to `ENABLE AUTO-SYNC`. | ||
|
||
Go back to the console and click on the Gitea app in the apps section. In the list of repo's you'll now see a new repo called `otomi/team-<name>-argocd`. | ||
|
||
data:image/s3,"s3://crabby-images/46422/46422d45a4e4b608391b30bf5e4763a3ba0778d8" alt="kubecfg" | ||
|
||
To show the power of Argo CD, let's add a manifest to the repo and see what happens. | ||
|
||
- Create a new file in the repo called `deploy-nginx.yaml` | ||
- Add the following contents to the file: | ||
|
||
``` | ||
apiVersion: apps/v1 | ||
kind: Deployment | ||
metadata: | ||
name: nginx | ||
labels: | ||
otomi.io/app: nginx | ||
app: nginx | ||
spec: | ||
replicas: 1 | ||
selector: | ||
matchLabels: | ||
app: nginx | ||
template: | ||
metadata: | ||
labels: | ||
app: nginx | ||
spec: | ||
containers: | ||
- name: nginx | ||
image: nginxinc/nginx-unprivileged:stable | ||
resources: | ||
limits: | ||
memory: '128Mi' | ||
cpu: '200m' | ||
requests: | ||
memory: '64Mi' | ||
cpu: '100m' | ||
ports: | ||
- containerPort: 8080 | ||
--- | ||
apiVersion: v1 | ||
kind: Service | ||
metadata: | ||
name: nginx | ||
spec: | ||
selector: | ||
app: nginx | ||
ports: | ||
- port: 80 | ||
targetPort: 8080 | ||
``` | ||
|
||
- Commit Changes | ||
|
||
Now go back to the Argo CD application and click on the `team<name>` application. | ||
|
||
Note that the Argo CD application is not configured to automatically SYNC. So click `SYNC` and then `REFRESH`. | ||
|
||
data:image/s3,"s3://crabby-images/ef583/ef5835d7b62a8cc7407e730e82cbdaab8bbf148a" alt="kubecfg" | ||
Deploying applications using `kubectl apply -f` can be inefficient. As a developer, managing resources based on code stored in Git enhances control and traceability. Otomi integrates with Argo CD to provide a seamless GitOps experience, streamlining your deployment process. | ||
|
||
## Deploying Workloads Using Argo CD and Otomi | ||
|
||
Start by navigating to the apps section in the Otomi console, where you will find an app named Argo CD. Click on it to proceed. | ||
|
||
data:image/s3,"s3://crabby-images/17ad0/17ad05268f2bbbe581985e9293316e7a99a1aac0" alt="Argo CD App in Otomi Console" | ||
|
||
In Argo CD, notice that an application specific to your team has already been set up. This application syncs with any manifest present in the Gitea repository designated for Argo. | ||
|
||
data:image/s3,"s3://crabby-images/b76f6/b76f65b57ac72a51c1304df04cc8e53261815a6e" alt="Argo CD Team Application Overview" | ||
|
||
After clicking on the app and selecting `APP DETAILS`, you'll find the `REPO URL`. The `SYNC POLICY` is also set to `ENABLE AUTO-SYNC`, facilitating automatic synchronization with the repository. | ||
|
||
Returning to the Otomi console, select the Gitea app in the apps section. There, you'll discover a new repository titled `otomi/team-<name>-argocd`. | ||
|
||
data:image/s3,"s3://crabby-images/46422/46422d45a4e4b608391b30bf5e4763a3ba0778d8" alt="Gitea Repository for Argo CD in Otomi" | ||
|
||
### Demonstrating the Power of Argo CD | ||
|
||
Let's demonstrate the capabilities of Argo CD by adding a manifest to the repository: | ||
|
||
1. Create a file named `deploy-nginx.yaml` in the repository. | ||
2. Insert the following contents into the file: | ||
|
||
```yaml | ||
apiVersion: apps/v1 | ||
kind: Deployment | ||
metadata: | ||
name: nginx | ||
labels: | ||
otomi.io/app: nginx | ||
app: nginx | ||
spec: | ||
replicas: 1 | ||
selector: | ||
matchLabels: | ||
app: nginx | ||
template: | ||
metadata: | ||
labels: | ||
app: nginx | ||
spec: | ||
containers: | ||
- name: nginx | ||
image: nginxinc/nginx-unprivileged:stable | ||
resources: | ||
limits: | ||
memory: '128Mi' | ||
cpu: '200m' | ||
requests: | ||
memory: '64Mi' | ||
cpu: '100m' | ||
ports: | ||
- containerPort: 8080 | ||
--- | ||
apiVersion: v1 | ||
kind: Service | ||
metadata: | ||
name: nginx | ||
spec: | ||
selector: | ||
app: nginx | ||
ports: | ||
- port: 80 | ||
targetPort: 8080 | ||
``` | ||
3. Commit the changes to the repository. | ||
Once you return to the Argo CD application, click on the `team<name>` application. | ||
|
||
Remember, the application is not configured for automatic syncing, so manually initiate a `SYNC` by selecting SYNC and then `REFRESH`. | ||
|
||
data:image/s3,"s3://crabby-images/ef583/ef5835d7b62a8cc7407e730e82cbdaab8bbf148a" alt="Syncing in ArgoCD" | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters