This project is a suggestion on who to use ArgoCD
as your Central infrastructure & Configuration Management tool for Openshift & Kubernetes based environments by using Openshift-GitOps
Operator and Helm Charts
.
As the title suggests, in this project I define everything that we may want to configure on our Openshift clusters (Post-Install infrastructure configurations) as Helm charts.
With Helm
we can define multiple values
files, that hold different variables for a specific chart, that upon deploying the chart Helm will "inject" into the yaml files.
The main advantage of incorporating ArgoCD with Helm charts is that we gain flexibility.
For each component (i.e. OAuth, Etcd, APIServer, Proxy, Ingress, etc.) , we have its different declarative yaml file/s that tell Openshift how it should work; By using Helm we can manage multiple Openshift Clusters with different configurations from a single ArgoCD instance.
In this project non of our applicationsets has these lines because its purpose is Cluster Management and most of the objects that this Argo manages should not/cannot be deleted by any means
-
Install Openshift-GitOps Operator
-
Create the central ArgoCD instance in a dedicated Namespace
Note! From a security point of view, the main Openshift-GitOps instance is for infrastructure management purposes, which is equivalent to Openshift admin configuring the cluster.
- Generate a ServiceAccount in each remote cluster that ArgoCD will manage with elevated permissions and link it to the central ArgoCD instance
-
Run the following commands to change the applicationsets so they will correlate with your clusters:
cd argo-objects/applicationsets/dev-ocp
sed -i 's,https://github.com/tommeramber/GitOps-For-Multi-Openshift-Cluster-Management.git,<YOUR FORKED REPO!!!>,g' *
sed -i 's,https://kubernetes.default.svc,<YOU **DEV** CLUSTER>,g' *
sed -i 's,name: apps, name: apps-dev,g'
sed -i 's,name: operators, name: operators-dev,g'
sed -i 's,name: core, name: core-dev,g'
cd argo-objects/applicationsets/prod-ocp
sed -i 's,https://github.com/tommeramber/GitOps-For-Multi-Openshift-Cluster-Management.git,<YOUR FORKED REPO!!!>,g' *
sed -i 's,https://kubernetes.default.svc,<YOU **PROD** CLUSTER>,g' *
sed -i 's,name: apps, name: apps-prod,g'
sed -i 's,name: operators, name: operators-prod,g'
sed -i 's,name: core, name: core-prod,g'
-
Change the
values-<env>-ocp.yaml
files in the different components' directories based on your environment needs -
Apply the following files based on your env (dev-ocp, prod-ocp (pocp), etc.)
$ cd GitOps-For-Multi-Openshift-Cluster-Management/argo-objects
$ oc apply -f projects
# oc apply -f applicationsets/<env>/.
$ oc apply -f applicationsets/dev-ocp/. #Example
Description in the video
This separation is only for convenience and based on my perspective, it is completely flexible and can be edited based on your needs, but don't forget to edit the ApplicationSets in the following dir
We have 4 main directories relevant for this solution;
-
Core - Every built-in component in Openshift/Kubernetes
-
Operators - Everything related to OLM operators, including imageContentSourcePolicies (ICSP), catalogSources , Subscriptions, CustomResources relevant for the specific Operator, etc.
-
Apps - Everything extra i.e. PersistentStorage 3rd Party CSI (e.g. Trident), helm operators / deployments for PaaS teams (e.g. Grafana, SealedSecrets, metricbeat, etc.)
-
Argo-Objects - This is the main directory that we are going to use with this project; It holds 2 things we must work within Argo -
4.1. Argo Projects - Logical separation to envrionments inside Argo; It can be used purely for organizing your apps and you can grant access to other teams in your organization to specific projects. In our case there is going to be a project per repo dir (core, apps, operators).
4.2. Argo ApplicationSets - Points ArgoCD to directories that holds our components, and it will create Argo Application for each of our charts, based on the
values-<env>.yaml
file for our specific environment. In our case there is going to be an applicationset per repo dir (core, apps, operators).
Argo ApplicationSet is an extension to the Kubernetes API provided by the ArgoCD operator.
Argo ApplicationSet tells Argo how to create Argo Application based on a template.
Using ApplicationSet object, we point ArgoCD to directories that hold our components. It will create Argo Application for each of our charts, based on the values-<env>.yaml
file for our specific environment.
From the ArgoCD site Apps can be deleted with or without a cascade option. A cascade delete, deletes both the app and its resources, rather than only the app. To perform a non-cascade delete, make sure your applicationsets does have the following lines:
syncPolicy:
preserveResourcesOnDeletion: true
You can take a look at the following component: etcd-encryption which defines if the etcd of a specific cluster should be encrypted or not.
For each cluster we have (dev-ocp, test-ocp, prod-ocp (pocp), etc.) values-<env>.yaml
in the specific chart directory, that holds the relevant values for this environment's needs. The most important value in this file is required
.
Each yaml file in this chart starts with a Helm if
statement that checks if this required
field is set to true
, and only if it does, it will create it with the values from the specific values-<env>.yaml
file.
In many cases you'll take existing charts/standard apps with multiple yaml files, and you'll want to apply the if
statement to the beginning of all of them with a one-liner and the closing end
to the end of them all; Run the following command to make it a reality:
for file in /PATH/TO/CHART/templates/*; do \
echo '{{- end }}' >> $file ;
sed -i '1i{{- if .Values.required}}' $file ;
done
For each new component that you want to add to the cluster, you need to:
- Decide in which upper-dir it should reside (core/apps/operators)
- Generate a new helm chart for this component
$ helm create <NAME>
- Create
values-<env>.yaml
for each environment you want - dev-ocp, prod-ocp (pocp), etc. with the proper variables for this component correlated to this environment.
The most important value is
required
that will define if the chart's objects should be deployed on this cluster or not.
- Create in the
templates
dir the yaml files that this component comprises. Each such yaml file should start with{{- if .Values.required }}
and end with{{- end }}
- Run the following command in the directory where the files
Chart.yaml
andvalues-<env>.yaml
are located, if it works, the chart is complete.
$ helm template . -f values-<env>.yaml
If you made a change in one of the
values-<env>.yaml
files, test it in the same manner.
.
├── apps
│ ├── helm-operators
│ │ ├── grafana
│ │ └── sealedsecerts
│ ├── metricbeat
│ └── trident
├── argo-objects
│ ├── applicationsets
│ │ └── dev-ocp
│ │ ├── apps.yaml
│ │ ├── core.yaml
│ │ └── operators.yaml
│ └── projects
│ ├── apps.yaml
│ ├── core.yaml
│ └── operators.yaml
├── core
│ ├── 500pods
│ ├── dnsforwarder
│ ├── etcd-encryption
│ │ ├── Chart.yaml
│ │ ├── templates
│ │ │ └── apiserver.yaml
│ │ └── values-dev-ocp.yaml
│ ├── jobs
│ │ ├── etcdbackup_cronjob
│ │ └── ldap-sync
│ ├── machine-config-pools
│ ├── machineconfigs
│ ├── oauth
│ │ ├── Chart.yaml
│ │ ├── files
│ │ │ ├── create_htpasswd.sh
│ │ │ └── htpasswd
│ │ ├── templates
│ │ │ ├── htpasswd-secret.yaml
│ │ │ └── oauth.yaml
│ │ └── values-dev-ocp.yaml
│ ├── project-bootstrap-template
│ ├── proxy
│ │ ├── Chart.yaml
│ │ ├── files
│ │ │ ├── ca.crt
│ │ │ ├── ca.key
│ │ │ ├── create-ca.sh
│ │ │ └── csr_answer.txt
│ │ ├── templates
│ │ │ ├── proxy.yaml
│ │ │ └── user-ca-bundle.yaml
│ │ └── values-dev-ocp.yaml
│ ├── rbac
│ │ ├── self-provisioner
│ │ │ ├── Chart.yaml
│ │ │ ├── templates
│ │ │ │ └── disable-self-provisioners.yaml
│ │ │ └── values-dev-ocp.yaml
│ │ └── serviceaccounts
│ └── scc
└── operators
├── catalogsources
├── imagecontentsourcepolicies
└── subs-and-customresources
├── gatekeeper
│ ├── Chart.yaml
│ ├── templates
│ │ ├── gatekeeper-instance.yaml
│ │ └── subscription.yaml
│ └── values-dev-ocp.yaml
└── monitoring
├── Chart.yaml
├── templates
│ └── cluster-monitoring-config.yaml
└── values-dev-ocp.yaml