- Fleet and Elastic Agent Guide: other versions:
- Fleet and Elastic Agent overview
- Beats and Elastic Agent capabilities
- Quick starts
- Migrate from Beats to Elastic Agent
- Deployment models
- Install Elastic Agents
- Install Fleet-managed Elastic Agents
- Install standalone Elastic Agents (advanced users)
- Install Elastic Agents in a containerized environment
- Run Elastic Agent in a container
- Run Elastic Agent on Kubernetes managed by Fleet
- Run Elastic Agent on GKE managed by Fleet
- Run Elastic Agent on Amazon EKS managed by Fleet
- Run Elastic Agent on Azure AKS managed by Fleet
- Run Elastic Agent Standalone on Kubernetes
- Scaling Elastic Agent on Kubernetes
- Using a custom ingest pipeline with the Kubernetes Integration
- Environment variables
- Installation layout
- Air-gapped environments
- Using a proxy server with Elastic Agent and Fleet
- Uninstall Elastic Agents from edge hosts
- Start and stop Elastic Agents on edge hosts
- Elastic Agent configuration encryption
- Secure connections
- Manage Elastic Agents in Fleet
- Configure standalone Elastic Agents
- Create a standalone Elastic Agent policy
- Structure of a config file
- Inputs
- Providers
- Outputs
- SSL/TLS
- Logging
- Feature flags
- Agent download
- Config file examples
- Grant standalone Elastic Agents access to Elasticsearch
- Example: Use standalone Elastic Agent to monitor nginx
- Debug standalone Elastic Agents
- Kubernetes autodiscovery with Elastic Agent
- Monitoring
- Reference YAML
- Manage integrations
- Define processors
- Processor syntax
- add_cloud_metadata
- add_cloudfoundry_metadata
- add_docker_metadata
- add_fields
- add_host_metadata
- add_id
- add_kubernetes_metadata
- add_labels
- add_locale
- add_network_direction
- add_nomad_metadata
- add_observer_metadata
- add_process_metadata
- add_tags
- community_id
- convert
- copy_fields
- decode_base64_field
- decode_cef
- decode_csv_fields
- decode_duration
- decode_json_fields
- decode_xml
- decode_xml_wineventlog
- decompress_gzip_field
- detect_mime_type
- dissect
- dns
- drop_event
- drop_fields
- extract_array
- fingerprint
- include_fields
- move_fields
- parse_aws_vpc_flow_log
- rate_limit
- registered_domain
- rename
- replace
- script
- syslog
- timestamp
- translate_sid
- truncate_fields
- urldecode
- Command reference
- Troubleshoot
- Release notes
Migrate Fleet-managed Elastic Agents from one cluster to another
editMigrate Fleet-managed Elastic Agents from one cluster to another
editThere are situations where you may need to move your installed Elastic Agents from being managed in one cluster to being managed in another cluster.
For a seamless migration, we advise that you create an identical agent policy in the new cluster that is configured in the same manner as the original cluster. There are a few methods to do this.
This guide takes you through the steps to migrate your Elastic Agents by snapshotting a source cluster and restoring it on a target cluster. These instructions assume that you have an Elastic Cloud deployment, but they can be applied to on-premise clusters as well.
Take a snapshot of the source cluster
editRefer to the full Snapshot and restore documentation for full details. In short, to create a new snapshot in an Elastic Cloud deployment:
- In Kibana, open the main menu, then click Manage this deployment.
- In the deployment menu, select Snapshots.
-
Click Take snapshot now.
Create a new target cluster from the snapshot
editYou can create a new cluster based on the snapshot taken in the previous step, and then migrate your Elastic Agents and Fleet to the new cluster. For best results, it’s recommended that the new target cluster be at the same version as the cluster that the agents are migrating from.
- Open the Elastic Cloud console and select Create deployment.
- Select Restore snapshot data.
- In the Restore from field, select your source deployment.
- Choose your deployment settings, and, optimally, choose the same Elastic Stack version as the source cluster.
-
Click Create deployment.
Update settings in the target cluster
editwhen the target cluster is available you’ll need to adjust a few settings. Take some time to examine the Fleet setup in the new cluster.
- Open the Kibana menu and select Fleet.
-
On the Agents tab, your agents should visible, however they’ll appear as
Offline
. This is because these agents have not yet enrolled in the new, target cluster, and are still enrolled in the original, source cluster. - Open the Fleet Settings tab.
-
Examine the configurations captured there for Fleet. Note that these settings are scopied from the snapshot of the source cluster and may not have a meaning in the target cluster, so they need to be modified accordingly.
In the following example, both the Fleet Server hosts and the Outputs settings are copied over from the source cluster:
The next steps explain how to obtain the relevant Fleet Server host and Elasticsearch output details applicable to the new target cluster in Elastic Cloud.
Modify the Elasticsearch output
edit-
In the new target cluster on Elastic Cloud, in the Outputs section, on the Fleet Settings tab, you will find an internal output named
Elastic Cloud internal output
. The host address is in the form:https://<cluster-id-target>.containerhost:9244
Record this
<cluster-id-target>
from the target cluster. In the example shown, the ID isfcccb85b651e452aa28703a59aea9b00
. -
Also in the Outputs section, notice that the default Elasticsearch output (that was copied over from the source cluster) is also in the form:
https://<cluster-id-source>.<cloud endpoint address>:443
.Modify the Elasticsearch output so that the cluster ID is the same as that for
Elastic Cloud internal output
. In this example we also rename the output toNew Elasticsearch
.In this example, the
New Elasticsearch
output and theElastic Cloud internal output
now have the same cluster ID, namelyfcccb85b651e452aa28703a59aea9b00
.
You have now created an Elasticsearch output that agents can use to write data to the new, target cluster. For on-premise environments not using Elastic Cloud, you should similarly be able to use the host address of the new cluster.
Modify the Fleet Server host
editLike the Elasticsearch host, the Fleet Server host has also changed with the new target cluster. Note that if you’re deploying Fleet Server on premise, the host has probably not changed address and this setting does not need to be modified. We still recommend that you ensure the agents are able to reach the the on-premise Fleet Server host (which they should be able to as they were able to connect to it prior to the migration).
The Elastic Cloud Fleet Server host has a similar format to the Elasticsearch output:
https://<deployment-id>.fleet.<domain>.io
To configure the correct Elastic Cloud Fleet Server host you will need to find the target cluster’s full deployment-id
, and use it to replace the original deployment-id
that was copied over from the source cluster.
The easiest way to find the deployment-id
is from the deployment URL:
- From the Kibana menu select Manage this deployment.
-
Copy the deployment ID from the URL in your browser’s address bar.
In this example, the new deployment ID is
eed4ae8e2b604fae8f8d515479a16b7b
.Using that value for
deployment-id
, the new Fleet Server host URL is:https://eed4ae8e2b604fae8f8d515479a16b7b.fleet.us-central1.gcp.cloud.es.io:443
-
In the target cluster, under Fleet server hosts, replace the original host URL with the new value.
Confirm your policy settings
editNow that the Fleet settings are correctly set up, it pays to ensure that the Elastic Agent policy is also correctly pointing to the correct entities.
- In the target cluster, go to Fleet → Agent policies.
- Select a policy to verify.
- Open the Settings tab.
-
Ensure that Fleet Server, Output for integrations, and Output for agent monitoring are all set to the newly created entities.
If you modified the Fleet Server and the output in place these would have been updated accordingly. However if new entities are created, then ensure that the correct ones are referenced here.
Agent policies in the new target cluster
editBy creating the new target cluster from a snapshot, all of your policies should have been created along with all of the agents. These agents will be offline due to the fact that the actual agents are not checking in with the new, target cluster (yet) and are still communicating with the source cluster.
The agents can now be re-enrolled into these policies and migrated over to the new, target cluster.
Migrate Elastic Agents to the new target cluster
editIn order to ensure that all required API keys are correctly created, the agents in your current cluster need to be re-enrolled into the new, target cluster.
This is best performed one policy at a time. For a given policy, you need to capture the enrollment token and the URL for the agent to connect to. You can find these by running the in-product steps to add a new agent.
- On the target cluster, open Fleet and select Add agent.
- Select your newly created policy.
- In the section Install Elastic Agent on your host, find the sample install command. This contains the details you’ll need to enroll the agents, namely the enrollment token and the Fleet Server URL.
-
Copy the portion of the install command containing these values. That is,
–url=<path> –enrollment-token=<token for the new policy>
. -
On the host machines where the current agents are installed, enroll the agents again using this copied URL and the enrollment token:
sudo elastic-agent enroll --url=<fleet server url> --enrollment-token=<token for the new policy>
The command output should be like the following:
-
The agent on each host will now check into the new Fleet Server and appear in the new target cluster. In the source cluster, the agents will go offline as they won’t be sending any check-ins.
- Repeat this procedure for each Elastic Agent policy.
If all has gone well, you’ve successfully migrated your Fleet-managed Elastic Agents to a new cluster.
On this page