Can anyone share their experience using GitOps workflows on DigitalOcean Kubernetes clusters? Which tools and practices worked best for managing application, deployments and setting up infrastructure with GitOps principles?
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
These answers are provided by our Community. If you find them useful, show some love by clicking the heart. If you run into issues leave a comment, or add your own answer to help others.
Sign up for Infrastructure as a Newsletter.
Working on improving health and education, reducing inequality, and spurring economic growth? We'd like to help.
Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.
I’ve been using GitOps with DO’s Kubernetes for a while now. For managing deployments and apps, ArgoCD is fantastic. It integrates well with Git and keeps things version controlled.Terraform is a great tool for infrastructure as code, allowing you to define your cluster and resources in Git.
Hey,
I’ve recently answered a similar question here:
Implementing GitOps workflows on DigitalOcean Kubernetes clusters can significantly simplify your deployment processes, ensuring a more manageable, transparent, and scalable infrastructure. Here’s a focused approach using one of the most popular tools in the GitOps space: Argo CD. This tool automates the deployment of applications to Kubernetes, maintaining the desired state specified in a Git repository.
Prerequisites
kubectl
configured to communicate with your DOKS clusterStep 1: Install Argo CD
First, install Argo CD on your DOKS cluster. This can be done via a single command using
kubectl
:This command creates a new namespace for Argo CD and applies the Argo CD installation manifests.
Step 2: Access Argo CD UI
To access the Argo CD UI, you’ll need to change the Argo CD server service from
ClusterIP
toLoadBalancer
:Wait a few moments, then retrieve the external IP:
Step 3: Log in to Argo CD
The initial password for the admin account is auto-generated and stored as a pod name. Retrieve it with:
Use the Argo CD CLI or UI to log in. If using the CLI:
Replace
<ARGOCD_SERVER_IP>
with the external IP from earlier. Useadmin
as the username and the retrieved pod name as the password.Step 4: Create an Application in Argo CD
Now, let’s create an application in Argo CD that points to your Git repository. This can be done via the Argo CD CLI or UI. Here’s how you might do it via the CLI:
Replace the repository URL (
--repo
) with your Git repository URL and--path
with the directory within your repository where your Kubernetes manifests are stored.Step 5: Sync Your Application
Finally, synchronize your application to match the desired state specified in your Git repository:
Best Practices
Repository Structure: Keep your application manifests, Helm charts, or Kustomize configurations in a dedicated repository or a distinct directory within an existing repository. This separation of concerns helps in managing changes and versioning.
Branching Strategy: Utilize a branching strategy (e.g., GitFlow or Trunk Based Development) that fits your team’s workflow. Typically, having a separate branch for each environment (dev, staging, production) can help manage deployments across different stages.
CI/CD Integration: Integrate Argo CD with your CI pipeline to automatically trigger deployments upon changes to your manifests. This could involve updating image tags in your deployment manifests after a successful build.
Monitoring and Alerts: Set up monitoring and alerts for your Argo CD instances and managed applications. Monitoring tools like Prometheus and Grafana can be integrated with Argo CD to track the health and performance of your deployments.
Best,
Bobby