Configure the Cluster Agent
This page describes the contents of the Cluster Agent bundle downloaded from the Download portal, and how to perform common configuration tasks:
See Cluster Agent YAML File Configuration Reference for configuration option details.
Directory Structure of the Cluster Agent Bundle
An unzipped Cluster Agent bundle contains this directory structure:
- Alpine Linux AMD
- 
            cluster-agent ├── cluster-agent-operator.yaml ├── appdynamics-operator-alpine-linux-amd64-<version> ├── cluster-agent-operator-openshift-1.15-or-less.yaml ├── cluster-agent-operator-openshift.yaml ├── cluster-agent.yaml ├── infraviz.yaml ├── README-alpine.md └── docker ├── cluster-agent.zip ├── Dockerfile ├── LICENSE └── start-appdynamics └── helm-charts ├── Chart.yaml ├── README.md ├── crds ├── templates └── values.yaml
- Alpine Linux ARM
- 
            cluster-agent ├── cluster-agent-operator.yaml ├── appdynamics-operator-alpine-linux-arm64-<version> ├── cluster-agent-operator-openshift-1.15-or-less.yaml ├── cluster-agent-operator-openshift.yaml ├── cluster-agent.yaml ├── infraviz.yaml ├── README-alpine.md └── docker ├── cluster-agent.zip ├── Dockerfile ├── LICENSE └── start-appdynamics └── helm-charts ├── Chart.yaml ├── README.md ├── crds ├── templates └── values.yaml
- Rhel Linux 7
- 
            cluster-agent ├── cluster-agent-operator.yaml ├── appdynamics-operator-rhel-linux-amd64-<version> ├── cluster-agent-operator-openshift-1.15-or-less.yaml ├── cluster-agent-operator-openshift.yaml ├── cluster-agent.yaml ├── README-rhel.md └── docker ├── cluster-agent.zip ├── Dockerfile-rhel ├── LICENSE └── start-appdynamics └── helm-charts ├── Chart.yaml ├── README.md ├── crds ├── templates └── values.yaml
Cluster Agent Bundle Files
This table describes the Cluster Agent directory files:
| File Name | Description | 
|---|---|
| appdynamics-operator-alpine-linux-amd64-<version> | The Splunk AppDynamics Operator artifacts contain Dockerfile, operator binary, licenses and scripts, which are used to build Alpine AMD-based Operator Images. | 
| appdynamics-operator-alpine-linux-arm64-<version> | The Splunk AppDynamics Operator artifacts contain Dockerfile, operator binary, licenses and scripts, which are used to build Alpine ARM-based Operator Images. | 
| appdynamics-operator-rhel-linux-amd64-<version> | The Splunk AppDynamics Operator artifacts contain Dockerfile-rhel, operator binary, licenses and scripts, which are used to build Rhel-based Operator Images. | 
| cluster-agent.yaml | File used to configure and deploy the Cluster Agent. 
 | 
| cluster-agent-operator.yaml | Files used to deploy the Cluster Agent Operator. These files set the default values for Kubernetes, Amazon EKS, and AKS, including a minimal set of RBAC permissions. | 
| cluster-agent-operator-openshift.yaml cluster-agent-operator-openshift-1.15-or-less.yaml | Files used to deploy the Cluster Agent on Red Hat OpenShift. These files set the default values for Red Hat OpenShift, including a minimal set of RBAC permissions. | 
| docker | Docker directory contains all files required to create the Cluster Agent image. | 
| Dockerfile | dockerfileused to create the Alpine-based Cluster Agent image. | 
| Dockerfile-rhel | dockerfileused to create the Rhel-based Cluster Agent image. | 
| infraviz.yaml | File used to configure and deploy the InfraViz. 
 | 
| LICENSE | Latest EULA file attached with the Cluster Agent image. | 
| cluster-agent.zip | Zip archive containing the Cluster Agent binaries and configuration files. | 
| helm-charts | Folder used to build the charts for deploying the Cluster Agent using Helm in Kubernetes. | 
| README-rhel.md README-alpine.md | Contains instructions on how to start the Cluster Agent using your preferred operating system. | 
| start-appdynamics | Script used to run the Cluster Agent within Docker. | 
Configure Proxy Support
To understand proxy in Kubernetes, see the Kubernetes documentation (Proxies in Kubernetes).
Configure the Cluster Agent to Use SSL for On-Premises Controllers
Controllers with Public and Self-Signed Certificates
To configure SSL with a public or self-signed certificate, use kubectl kubectl
kubectl -n appdynamics create secret generic ssl-cert --from-file=<path-to-your-self-signed-certs>/custom-ssl.pemThe certificate file must be named: custom-ssl.pem
After your secret is created, you must add the customSSLSecret cluster-agent.yaml
customSSLSecret: “ssl-cert”Proxy and On-Premises Certificates Combined
If you have two different SSL certificates (one for the proxy server, and a different one for the on-premises Controller), then you can encapsulate both of them into a single secret:
kubectl -n appdynamics create secret generic ssl-cert --from-file=proxy-ssl.pem --from-file=<path-to-your-self-signed-certs>/custom-ssl.pemThe Cluster Agent pulls each certificate from the secret identified in the customSSLSecret
This example shows a cluster-agent.yaml customSSLSecret file with the
apiVersion: cluster.appdynamics.com/v1alpha1
kind: Clusteragent
metadata:
name: k8s-cluster-agent-manual
namespace: appdynamics
spec:
# init agent configuration
appName: "test-k8s-cluster-agent"
controllerUrl: "https://<controller-url>:443" # always schema and port
account: "<account-name>" # account
# agent related properties
# custom SSL secret name
customSSLSecret: "ssl-cert"
# logging properties
logLevel: INFO
logFileSizeMb: 7
logFileBackups: 6
# docker image info
image: "<image-url>"Create Secret
If the Cluster Agent requires a secret to pull images from a container registry, use the Kubernetes API to create the secret and reference it in cluster-agent.yaml
- Kubernetes
- $ kubectl -n appdynamics create secret docker-registry myregcred --docker-server=https://index.docker.io/v1 --docker-username=<docker-username> --docker-password=<docker-password> --docker-email=unused
- OpenShift
- $ oc -n appdynamics create secret docker-registry myregcred --docker-server=https://index.docker.io/v1 --docker-username=<docker-username> --docker-password=<docker-password> --docker-email=unused $ oc -n appdynamics secrets link appdynamics-operator regcred --for=pull
Set the imagePullSecret cluster-agent.yaml myregcred
kind: Clusteragent
metadata:
name: k8s-cluster-agent
namespace: appdynamics
spec:
appName: "mycluster"
controllerUrl: "http://<appdynamics-controller-host>:8080"
account: "<account-name>"
image: "<your-docker-registry>/appdynamics/cluster-agent:tag"
serviceAccountName: appdynamics-cluster-agent
imagePullSecret: "myregcred"Cluster AgentYAMLFile Configuration Reference
To configure the Cluster Agent, use the cluster-agent.yaml
| Parameter | Description | Example | Default | Dynamically Configurable? | Type | Required? | 
|---|---|---|---|---|---|---|
| account | Splunk AppDynamics account name. | admin | N/A | No | String | Required | 
| appName | Name of the cluster; displays in the Controller UI as your cluster name. Note: Ensure that this name is unique for each Cluster Agent that is installed in same cluster or in different cluster that is part of the same Controller. | k8s-cluster | N/A | No | String | Required | 
| controllerUrl | Full Splunk AppDynamics Controller URL, including protocol and port. | HTTP: http://appd-controller.com:8090/ HTTPS: https://appd-controller.com:443 | N/A | No | String | Required | 
| customSSLSecret | Provides the self-signed or public certificates to the Cluster Agent. | "ssl-cert" | N/A | No | String | Optional | 
| eventUploadInterval | How often Kubernetes warning and state-change events are uploaded to the Controller in seconds. See Monitor Kubernetes Events. | 10 | 10 | No | Integer | Optional | 
| httpClientTimeout | If no response is received from the Controller, number of seconds after which the server call is terminated. | 30 | 30 | No | Integer | Optional | 
| image | Cluster Agent image. | your-docker-registry/appdynamics/cluster-agent:latest | N/A | No | String | Required | 
| imagePullPolicy | Image pull policy for cluster agent. | IfNotPresent | Always | No | String | Optional | 
| imagePullSecret | Credential file used to authenticate when pulling images from your private Docker registry or repository. Based on your Docker registry configuration, you may need to create a secret file for the Splunk AppDynamics Operator to use when pulling the image for the Cluster Agent. See Create a Secret by providing credentials on the command line. | regcred | N/A | No | String | Optional | 
| instrumentationMaxPollingAttempts | The maximum number of times Cluster Agent checks for the successful rollout of instrumentation before marking it as failed. | instrumentationMaxPollingAttempts: 15 | 10 | Yes | integer | Optional | 
| instrumentationNsStatusPollingIntervalMinutes | The polling interval to add or remove the APPD_INSTRUMENTATION_CLUSTER_AGENT annotation. This is applicable for the agents that are part of the same cluster. When a namespace is uninstrumented from a Cluster Agent, this parameter periodically checks at the defined interval to remove the annotation from that Cluster Agent. | instrumentationNsStatusPollingIntervalMinutes: 10 | 5 | Yes | Integer | Optional | 
| labels | Adds any required pod labels to the Cluster Agent pod. These labels are also added to the deployment of Cluster Agent. | labels: key1: value1 key2: value2 | The following labels are created by default and cannot be modified: name clusterAgent clusterAgent_cr pod-template-hashname of agent> assigned by Kubernetes> Note: The key value pairs that you specify for this parameter gets added to the Cluster Agent pod along with the default value. | No | map[string]string | Optional | 
| logFileSizeMb | Maximum file size of the log in MB. | 5 | 5 | Yes | Integer | Optional | 
| logFileBackups | Maximum number of backups saved in the log. When the maximum number of backups is reached, the oldest log file after the initial log file is deleted. | 3 | 3 | Yes | Integer | Optional | 
| logLevel | Number of log details. INFO,WARNING,DEBUG, orTRACE. | "INFO" | INFO | Yes | String | Optional | 
| maxPodLogsTailLinesCount | Number of lines to be tailed while collecting logs. To use this parameter, enable the log capturing feature. See Enable Log Collection for Failing Pods. | 500 | 500 | Yes | Integer | Optional | 
| nodeSelector | The Cluster Agent pod runs on the node that includes the specified key-valuepair within its labels property. See nodeSelector. | nodeSelector: kubernetes.io/e2e-az-name: az1 | N/A | No | map[string]string | Optional | 
| nsToMonitorRegex | The regular expression for selecting the required namespaces to be monitored in the cluster. If you require to monitor multiple namespaces, separate the namespaces using | If you are using Target Allocator, you must specify all the namespaces that you require to monitor. Target Allocator will auto-allocate these Namespaces to each Cluster Agent replicas. See Edit Namespaces. Note: Any modification to the namespaces in the UI takes the precedence over the yaml configuration. | 
 | N/A | Yes | Regular expression | Optional | 
| nsToExcludeRegex | The regular expression for the namespaces that must be excluded from the selected namespaces that match the regular expression mentioned for nsToMonitorRegex Note: 
                                     
 This parameter can be used only if you have specified a value for the nsToMonitorRegex | nsToExcludeRegex: ns.* | N/A | Yes | Regular expression | Optional | 
| podFilter | Blocklist or allowlist pods based on: 
 Blocklisting or allowlisting by name takes preference over blocklisting or allowlisting by labels. For example, if you have the podFilter podFilter: blocklistedLabels: - release: v1 allowlistedNames: - ^podname This blocks all the pods which have the label ' release=v1' podname' 
 |   | N/A | Yes | String | Optional | 
| priorityClassName | The name of the pod priority class, which is used in the pod specification to set the priority. | priorityClassName: system-node-critical | N/A | No | String | Optional | 
| proxyUrl | Publicly accessible host name of the proxy. | https://myproxy.example.com:8080 | N/A | No | String | Optional | 
| proxyUser | Username associated with the basic authentication credentials. | "user1" | N/A | No | String | Optional | 
| resources | Requests and limits of CPU and memory resources for the Cluster Agent. | resources: limits: cpu: 300m memory: "200Mi" requests: cpu: 200m memory: "100Mi" | 
 | Yes | Array | Optional | 
| stdoutLogging | By default, the Cluster Agent writes to a log file in the logs stdoutLogging stdout | "true", "false" | true | Yes | String | Optional | 
| targetAllocator | 
 | 
 | ||||
| tolerations | An array of tolerations required for the pod. SeeTaint and Tolerations. | tolerations: - effect: NoSchedule key: type value: test - effect: NoExecute key: node.kubernetes.io/not-readyoperator: Exists tolerationSeconds: 600 | N/A | No | Array | Optional | 
| securityContext Note: For OpenShift version > 4.14, ensure that all the child parameters within securityContext are specified based on the permissible values outlined by the security context constraints (SCCs). See Managing Security Context Constraints in the Red Hat OpenShift documentation.For example, if you want to use RunAsUser property, then user ID (UID) should be in the permissible range. The SCCs permissible range for UID is 1000 to 9001. Therefore, you can add the RunAsUser value within this range only. The same applies to other security context parameters. | You can include the following parameters under securityContext runAsGroup groupId This sets the appropriate file permission on the agent artifacts. This value is applied to all the instrumented resources. Add this parameter, if you require to override the default value of runAsGroup |  | N/A | No | Array | Optional | 
| runAsUser userId This sets the appropriate file permission on the agent artifacts. This value is applied to all the instrumented resources. Add this parameter, if you require to override the default value of runAsUser | ||||||
| allowPrivilegeEscalation 
 If you do not set this parameter, the helm uses the default value as true. Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| capabilities Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| privileged If you do not set this parameter, the helm uses the default value as true. Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| procMount Note: This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| readOnlyRootFilesystem Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| runAsNonRoot If the value is true, the Kubelet validates the image at runtime to ensure that the container fails to start when run as root. If this parameter is not specified or if the value is false, there is no validation. Note: This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| seLinuxOptions Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| seccompProfile Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | ||||||
| windowsOptions Note: This parameter is unavailable when spec.os.name is Windows.This parameter is currently available for Deployment and DeploymentConfig mode. | 
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
name: appdynamics-cluster-agent-instrumentation
subjects:
- kind: ServiceAccount
name: appdynamics-cluster-agent
namespace: appdynamics
roleRef:
kind: ClusterRole
name: appdynamics-cluster-agent-instrumentation
apiGroup: rbac.authorization.k8s.ioCluster Agent File Example
This example shows a cluster-agent.yaml
apiVersion: cluster.appdynamics.com/v1alpha1
kind: Clusteragent
metadata:
name: k8s-cluster-agent
namespace: appdynamics
spec:
appName: "<app-name>"
controllerUrl: "<protocol>://<appdynamics-controller-host>:8080"
account: "<account-name>"
# docker image info
image: "<your-docker-registry>/appdynamics/cluster-agent:tag"
nsToMonitorRegex: namespace1|namespace2
eventUploadInterval: 10
containerRegistrationInterval: 120
httpClientTimeout: 30
customSSLSecret: "<secret-name>"
proxyUrl: "<protocol>://<domain>:<port>"
proxyUser: "<proxy-user>"
metricsSyncInterval: 30
clusterMetricsSyncInterval: 60
metadataSyncInterval: 60
containerBatchSize: 25
containerParallelRequestLimit: 3
podBatchSize: 30
metricUploadRetryCount: 3
metricUploadRetryIntervalMilliSeconds: 5
podFilter:
# blocklistedLabels:
#   - label1: value1
# allowlistedLabels:
#   - label1: value1
#   - label2: value2
# allowlistedNames:
#   - name1
# blocklistedNames:
#   - name2
logLevel: "INFO"
logFileSizeMb: 5
logFileBackups: 3
stdoutLogging: "true"
resources:
limits:
cpu: 300m
memory: "200Mi"
requests:
cpu: 200m
memory: "100Mi"
labels:
key1: value1
key2: value2Cluster Agent File Example
This example shows a cluster-agent.yaml configuration file:
apiVersion: cluster.appdynamics.com/v1alpha1
kind: Clusteragent
metadata:
  name: k8s-cluster-agent
  namespace: appdynamics
spec:
  appName: "<app-name>"
  controllerUrl: "<protocol>://<appdynamics-controller-host>:8080"
  account: "<account-name>"
  # docker image info
  image: "<your-docker-registry>/appdynamics/cluster-agent:tag"
  nsToMonitorRegex: namespace1|namespace2
  eventUploadInterval: 10
  containerRegistrationInterval: 120
  httpClientTimeout: 30
  customSSLSecret: "<secret-name>"
  proxyUrl: "<protocol>://<domain>:<port>"
  proxyUser: "<proxy-user>"
  metricsSyncInterval: 30
  clusterMetricsSyncInterval: 60
  metadataSyncInterval: 60
  containerBatchSize: 25
  containerParallelRequestLimit: 3
  podBatchSize: 30
  metricUploadRetryCount: 3
  metricUploadRetryIntervalMilliSeconds: 5
  podFilter:
    # blocklistedLabels:
    #   - label1: value1
    # allowlistedLabels:
    #   - label1: value1
    #   - label2: value2
    # allowlistedNames:
    #   - name1
    # blocklistedNames:
    #   - name2
  logLevel: "INFO"
  logFileSizeMb: 5
  logFileBackups: 3
  stdoutLogging: "true"
  resources:
	limits:
		cpu: 300m
		memory: "200Mi"
	requests:
		cpu: 200m
		memory: "100Mi"
  labels:
	 key1: value1
     key2: value2