DaemonSet
The Aperture Agent can be installed as a Kubernetes DaemonSet, where it will get deployed on all the nodes of the cluster.
Prerequisites
You can do the installation using the aperturectl CLI tool or using Helm.
Install the tool of your choice using the following links:
- Referaperturectl install agent to see all the available command line arguments. 
- Once the Helm CLI is installed, add the Aperture Agent Helm chart repository in your environment for install or upgrade: - helm repo add aperture https://fluxninja.github.io/aperture/
 helm repo update
 
Installation
The Aperture Agent in the DaemonSet mode will be installed using the Kubernetes Custom Resource, which will be managed by the Aperture Operator.
By following these instructions, you will have deployed the Aperture Agent into your cluster.
Kubernetes Objects which will be created by following steps are listed here.
- Configure the below parameters of etcd and Prometheus for the Agent Custom Resource by creating a - values.yamland passing it with- installcommand:- agent:
 config:
 etcd:
 endpoints: ["ETCD_ENDPOINT_HERE"]
 prometheus:
 address: "PROMETHEUS_ADDRESS_HERE"
 agent_functions:
 endpoints: ["CONTROLLER_ENDPOINT_HERE"]- Replace the values of - ETCD_ENDPOINT_HEREand- PROMETHEUS_ADDRESS_HEREwith the actual values of etcd and Prometheus, which is also being used by the Aperture Controller you want these Agents to connect to.- CONTROLLER_ENDPOINT_HEREshould point to the Aperture Controller. If you skip it, some sub commands- aperturectlcommands won't work.- If you have installed the Aperture Controller on the same cluster in - defaultnamespace, with etcd and Prometheus using- controlleras release name, the values for the values for- ETCD_ENDPOINT_HERE,- PROMETHEUS_ADDRESS_HEREand- CONTROLLER_ENDPOINT_HEREwould be as below:- agent:
 config:
 etcd:
 endpoints: ["http://controller-etcd.default.svc.cluster.local:2379"]
 prometheus:
 address: "http://controller-prometheus-server.default.svc.cluster.local:80"
 agent_functions:
 endpoints: ["aperture-controller.default.svc.cluster.local:8080"]- aperturectl
- Helm
 - aperturectl install agent --version v2.8.0 --values-file values.yaml- helm install agent aperture/aperture-agent -f values.yaml
- If you want to modify the default parameters or the Aperture Agent configuration, for example - log, you can create or update the- values.yamlfile and pass it with- installcommand:- agent:
 config:
 etcd:
 endpoints: ["http://controller-etcd.default.svc.cluster.local:2379"]
 prometheus:
 address: "http://controller-prometheus-server.default.svc.cluster.local:80"
 log:
 level: debug
 pretty_console: true
 non_blocking: false- aperturectl
- Helm
 - aperturectl install agent --version v2.8.0 --values-file values.yaml- helm install agent aperture/aperture-agent -f values.yaml- All the configuration parameters for the Aperture Agent are available here. - A list of configurable parameters for the installation can be found in the README. 
- If you want to deploy the Aperture Agent into a namespace other than - default, use the- --namespaceflag:- aperturectl
- Helm
 - aperturectl install agent --version v2.8.0 --values-file values.yaml --namespace aperture-agent- helm install agent aperture/aperture-agent -f values.yaml --namespacen aperture-agent --create-namespace
- Alternatively, you can create the Agent Custom Resource directly on the Kubernetes cluster using the below steps: - Create a - values.yamlfor just starting the operator and disabling the creation of Agent Custom Resource and pass it with- installcommand:- agent:
 create: false- aperturectl
- Helm
 - aperturectl install agent --version v2.8.0 --values-file values.yaml- helm install agent aperture/aperture-agent -f values.yaml
- Create a YAML file with the following specifications: - apiVersion: fluxninja.com/v1alpha1
 kind: Agent
 metadata:
 name: Agent
 spec:
 config:
 etcd:
 endpoints: ["ETCD_ENDPOINT_HERE"]
 prometheus:
 address: "PROMETHEUS_ADDRESS_HERE"- Replace the values of - ETCD_ENDPOINT_HEREand- PROMETHEUS_ADDRESS_HEREwith the actual values of etcd and Prometheus, which is also being used by the Aperture Controller you want these Agents to connect to.- All the configuration parameters for the Agent Custom Resource are listed on the README file of the Helm chart. 
- Apply the YAML file to Kubernetes cluster using - kubectl- kubectl apply -f agent.yaml
 
- Refer to steps on the Istio Configuration if you do not have the Envoy Filter configured on your cluster. 
Upgrade Procedure
By following these instructions, you will have deployed the upgraded version of Aperture Agent into your cluster.
- Use the same - values.yamlfile created as part of the Installation Steps and pass it with below command:- aperturectl
- Helm
 - aperturectl install agent --version v2.8.0 --values-file values.yaml- helm template --include-crds --no-hooks agent aperture/aperture-agent -f values.yaml | kubectl apply -f -- Once all the pods are in a running state after upgrade, run the below command to keep the Helm release updated: - helm upgrade agent aperture/aperture-agent -f values.yaml
- If you have deployed the Aperture Agent into a namespace other than - default, use the- --namespaceflag:- aperturectl
- Helm
 - aperturectl install agent --version v2.8.0 --values-file values.yaml --namespace aperture-agent- helm template --include-crds --no-hooks agent aperture/aperture-agent -f values.yaml --namespace aperture-agent | kubectl apply -f -- Once all the pods are in a running state after upgrade, run the below command to keep the Helm release updated: - helm upgrade agent aperture/aperture-agent -f values.yaml --namespace aperture-agent
Verifying the Installation
Once you have successfully deployed the resources, confirm that the Aperture Agent is up and running:
kubectl get pod -A
kubectl get agent -A
You should see pods for Aperture Agent and Agent Manager in RUNNING state and
Agent Custom Resource in created state.
Uninstall
You can uninstall the Aperture Agent and its components installed above by following these steps:
- Uninstall the Aperture Agent: - aperturectl
- Helm
 - aperturectl uninstall agent --version v2.8.0- helm uninstall agent
- Alternatively, if you have installed the Aperture Agent Custom Resource as a standalone installation, follow the steps below: - Delete the Aperture Agent Custom Resource: - kubectl delete -f agent.yaml
- Delete the Aperture Agent to uninstall the Aperture Operator: - aperturectl
- Helm
 - aperturectl uninstall agent --version v2.8.0- helm uninstall agent
 
- If you have installed the chart in some other namespace than the - default, execute the following commands:- aperturectl
- Helm
 - aperturectl uninstall agent --namespace aperture-agent- helm uninstall agent --namespace aperture-agent
 kubectl delete namespace aperture-agent
- By default, the Secret having SSL/TLS certificates generated by the Kubernetes Operator for itself is not deleted with above steps. If you want to delete it, run the following commands: - kubectl delete secret -l app.kubernetes.io/instance=agent-aperture-agent-manager
- Optional: Delete the CRD installed by the Helm chart: note- Deleting a Helm chart using Helm does not delete the Custom Resource Definitions (CRD) installed from the chart. - kubectl delete crd agents.fluxninja.com