- Tableau Migration App - Table of Contents
You can download the Tableau Migration App from the releases page of this repo.
The purpose of the Tableau Migration App is to provide users with a method to perform simple migrations from their Tableau Server to Tableau Cloud. This app is meant to accompany the Tableau Manual Migration Guide and replace the work required for the migration steps.
-
The migration app uses the Tableau Migration SDK under the hood, and supports all migration resources that the Migration SDK offers.
- The Migration SDK currently includes:
- Users
- Groups
- Projects
- Data Sources
- Workbooks
- Extract Refresh Tasks
- Custom Views
- The Migration SDK currently includes:
-
Basic mapping options are provided in the app for username migrations.
-
A simplified view of ongoing migration progress.
The fields in this section are for providing the URIs of the Tableau Server you wish to migrate from, and the Tableau Cloud you wish to migrate to.
These URIs can be found in your browser address bar when logging into the respective Tableau products, or are what you use when connecting from Tableau Desktop.
The
Base URI
andSite Name
fields will automatically extract the appropriate information based on the URI provided. Double check that these are correct before continuing.
Note: Multi-site environments show the /site/
as part of the URI. If yours doesn’t have one, it isn’t a problem, and just means that you only have a single site; the Default
site.
The app uses personal access tokens (PATs) to programmatically access and make changes to the corresponding Tableau products.
To generate PATs in your Tableau Environment:
-
Go to Users > {Your User Here} > Settings > Personal Access Tokens.
-
Provide a Token name.
-
Click the Create Token button.
-
After it’s created, a
secret
will be displayed to you for that PAT. Click Copy Secret. -
In the Migration app:
- Enter the Token Name in the PAT Name field.
- Enter the Secret that you copied earlier in the PAT field.
This needs to be done separately for both the source Tableau Server and the destination Tableau Cloud. Each PAT only provides access to the system it was generated on.
Note The PAT only provides access to resources the user is authorized to have. Resources that the PAT owner doesn’t have access to will not be migrated.
!Important! Users in Tableau Cloud must have a username in the form of an email. Because Tableau Server doesn’t have this restriction, we've provided different ways for you to designate how the users should be migrated if they don't currently follow this format. The different cases are detailed below.
The order of priority of defined mappings for the migration are:
- CSV-defined mapping
- Username already in email format
- User has an associated email
- Default domain mapping
This means that if a defined mapping is found for a user in the CSV file, that mapping is used even if the user has an associated email.
The following sections detail more about each mapping option.
If a username is already in an email format, then nothing needs to be done and the user will be migrated over as is.
If a user has an associated email set to the profile, that email will instead be used for the user when migrating.
We also provide a default domain mapping. When this is done, all users will have their names appended with that domain to create an email.
For example, if a user with username PeterP
is to be migrated, and the Default User Domain
is set to DailyBugle.com
, then that user will be migrated to Tableau Cloud as [email protected]
This option can be disabled by clicking the checkbox. In this case, users that don’t have a mapping found from the other options will not be migrated to Tableau Cloud.
Note Users containing illegal email characters in their usernames will still fail migration even with a default domain mapped. For example [][email protected]
isn’t a valid username for Tableau Cloud.
Note2 Users with a space in their Tableau Server usernames such as Renee Montoya
will have their spaces replaced with a .
instead, becoming [email protected]
.
For more fine-grained control over how individual users are migrated, you can define specific user mappings in a CSV file.
To do so, the file should contain one user mapping per line, separated by a comma (,
).
That is, every line should look like: {TableauServerUserName},{TableauCloudUsername}
The {TableauServerUserName}
MUST match the username exactly and is case-sensitive or else the user will not be mapped.
Here’s an example of the proper file format:
example.csv
:
Timmy Turner, [email protected]
Velma Dinkley, [email protected]
Leonardo, [email protected]
...
Note Starting and trailing white spaces are trimmed. user1 , [email protected]
is the same as user1,[email protected]
for the sake of legibility.
Ongoing outputs of the running Migration will be shown in the output window.
After migration of a resource is completed, whether successful or not, an associated message shows in the window.
Application logs can be found in the Logs
folder from where the application is run. These logs contain all the REST requests made by the underlying Tableau Migration SDK to the Tableau environments to perform the migration.
These logs can be used to provide further insight to the ongoing status and/or errors of the migration.
When a migration is running, a Cancel Migration button appears. If you want to stop the current migration, you can click this button. Doing so will also present you with a dialog window to save a manifest file.
This manifest can be used to resume a migration later and continue where you left off.
If you have a manifest file saved from a previous run, you can resume a migration by selecting the dropdown arrow on the right side of the Start Migration
button and selecting Resume Migration
.
Check the logs. It could be that the current resource is large and is taking a long time to migrate.
Or it could be that the application has hit its limit on the number of requests it can make in the current time frame, and is waiting until it can send more. In this case, the logs messages should mention how much longer it needs to wait for.
If you want finer control over how the migration is handled, such as renaming resources or applying special rules like reassigning resources, then we recommend that you use the Tableau Migration SDK to programmatically perform the migration.
You can either delete the items after the migration is performed, or you’ll have to use the Tableau Migration SDK
Resources are first sorted from largest to smallest, and migrated in that order.
The Tableau Migration App is community supported. Using it you can accidentally modify or delete your content, just as you can accidentally do so in the user interface. Despite efforts to write good and useful code there may be bugs that cause unexpected and undesirable behavior. The software is strictly “use at your own risk.”
The good news: This is intended to be a self-service tool. You are free to modify it in any way to meet your needs.