Historically we have only had a single instance in the US. Hosted Mender instances are now available in multiple regions as a result of our expansion. This document will describe the migration process if you currently have a fleet of devices operating in one instance and would like to move them to another one.
Migration between instances without risks requires support assistance and is a payed service available only to the Enterprise plan. If you wish to migrate your account please contact us on support@mender.io with the subject Tenant migration.
Please note that this method only applies for hosted Mender instances and isn't applicable for on-premise migrations.
Going forward, the following terms will be used for clarity:
The following steps summarize the procedure for moving from one server to another:
The diagram below, describes the flow
If you wish to migrate your account please contact us on support@mender.io with the title Tenant migration. In that request please share you "Organization name" as registered in Mender in "Organization and billing". We will get back to you once the tenant has been cloned and you can proceed to the next step.
This will largely depend on the way you create build artifacts.
Regardless of the approach the goal to update the device so it's config (/etc/mender/mender.conf
) changes from:
{
"ServerURL": "https://hosted.mender.io",
"TenantToken": "abcdefghijklm1234567890",
... <Other config parameters>
}
to
{
"Servers": [
{
"ServerURL": "https://hosted.mender.io"
},
{
"ServerURL": "https://eu.hosted.mender.io"
}
],
"TenantToken": "abcdefghijklm1234567890",
... <Other config parameters>
}
Make sure you removed the ServerURL
entry from the top of the JSON configuration. More info here.
Please check bellow for different approaches on how to achieve this:
If you deploy a config file with a badly formatted json, mender-updated
on the device won't start correctly after the update.
The device will roll back to the previous version only after the device is restarted by other means.
During that server will show the deployment status as "rebooting" and after the roll back the deployment will fail.
Please make sure to test the migration with one device first before deploying it to the whole production fleet.
Once the deployment was successful and the device restarts, it will try communicating with the first server on the list. That is the Old server.
As we want to stop the communication with the Old server, reject the device.
As the device cannot connect to the first server on the list (Old server), it will try with the next one. In this case, it is the New server.
Once the device is correctly showing on the New server the last step is to deploy the configuration containing only the New server.
{
"ServerURL": "https://eu.hosted.mender.io",
"TenantToken": "abcdefghijklm1234567890",
... <Other config parameters>
}
For Yocto project integrations, if you are already passing your own configuration file to the build,
as described in Customize Mender, modify your mender.conf
to include Servers
array.
If instead you are relying on meta-mender
to autogenerate a configuration file based on variables
you need to first capture the currently generated mender.conf
, modify it, and use the Customize
Mender method
to inject it back into the build. The file can be captured from a live device or from yocto
tmp/deploy/
directory (which will depend a bit on your setup).
At the end of the process you should have two mender artifacts:
Similarly for Debian family integrations, if you are already passing your own configuration file with a rootfs overlay, modify your mender.conf
to include Servers
array.
If instead you rely on the autogenerated mender.conf
, capture it, modify it, and set it up in a rootfs overlay.
The fields that need modification are:
ServerURL
shall be set to: ""
(empty string)Servers
shall be set to: [{ServerURL: "https://hosted.mender.io"}, {ServerURL: "https://eu.hosted.mender.io"}]
You can do this manually with any text editor or using the jq
command:
cat mender.conf | jq '
.ServerURL = "" | # Blank existing ServerURL
.Servers = [ # Set Servers array of ServerURL(s)
{ServerURL: "https://hosted.mender.io"},
{ServerURL: "https://eu.hosted.mender.io"}
]' > mender.new.conf
At the end of the process you should have two mender artifacts:
© 2025 Northern.tech AS