mapped_pages |
---|
For basic {{agent}} managed by {{fleet}} scenarios follow the steps in Run {{agent}} on Kubernetes managed by {{fleet}}.
On managed {{agent}} installations it can be useful to provide the ability to configure more advanced options, such as the configuration of providers during the startup. Refer to Providers for more details.
Following steps demonstrate above scenario:
It is advisable to follow the steps of Install {{fleet}}-managed {{agent}}s with Kubernetes Integration installed in your policy and download the {{agent}} manifest from Kibana UI
:::{image} images/k8skibanaUI.png :alt: {{agent}} with K8s Package manifest :::
Notes : Sample manifests can also be found here
apiVersion: v1
kind: ConfigMap
metadata:
name: agent-node-datastreams
namespace: kube-system
labels:
k8s-app: elastic-agent
data:
agent.yml: |-
providers.kubernetes_leaderelection.enabled: false
fleet.enabled: true
fleet.access_token: "<FLEET_ENROLLMENT_TOKEN>"
---
Notes
: 1. In the above example the disablement of kubernetes_leaderelection
provider is demonstrated. Same procedure can be followed for alternative scenarios.
apiVersion: v1
kind: ConfigMap
metadata:
name: agent-node-datastreams
namespace: kube-system
labels:
k8s-app: elastic-agent
data:
agent.yml: |-
providers.kubernetes:
add_resource_metadata:
deployment: true
cronjob: true
fleet.enabled: true
fleet.access_token: "<FLEET_ENROLLMENT_TOKEN>"
---
- Find more information about Enrollment Tokens.
Inside the downloaded manifest, update the Daemonset resource:
containers:
- name: elastic-agent
image: docker.elastic.co/elastic-agent/elastic-agent: <ImageVersion>
args: ["-c", "/etc/elastic-agent/agent.yml", "-e"]
Notes
: The is just a placeholder for the elastic-agent image version that you will download in your manifest: eg. image: docker.elastic.co/elastic-agent/elastic-agent: 8.11.0
Important thing is to update your manifest with args details
volumeMounts:
- name: datastreams
mountPath: /etc/elastic-agent/agent.yml
readOnly: true
subPath: agent.yml
volumes:
- name: datastreams
configMap:
defaultMode: 0640
name: agent-node-datastreams
- By default the manifests for {{agent}} managed by {{fleet}} have
hostNetwork:true
. In order to support multiple installations of {{agent}}s in the same node you should sethostNetwork:false
. See this relevant example as described in {{agent}} Manifests in order to support Kube-State-Metrics Sharding. - The volume
/usr/share/elastic-agent/state
must remain mounted in elastic-agent-managed-kubernetes.yaml, otherwise custom config map provided above will be overwritten.