You may want to export your Looker (Google Cloud core) instance data — which includes created content and internal data about your Looker (Google Cloud core) instance — from one Looker (Google Cloud core) instance, and then import that data to another Looker (Google Cloud core) instance. There are several reasons that you may want to export and import data:
- You want to upgrade or downgrade to a different edition of Looker (Google Cloud core).
- You want to move to a Looker (Google Cloud core) instance in a different project.
- You want to move to a Looker (Google Cloud core) instance in a different region.
- You want to export data from a non-production instance to your production instance.
An export includes all data, configurations, and content from an instance, with the following exceptions:
- Any Google Cloud console settings, which must be made in the Google Cloud console for each instance, are not exported. However, settings in the Looker Admin panel within the Looker (Google Cloud core) application are exported.
- Any OAuth tokens that are stored in an instance are not exported. If using OAuth for individual database connections, after import each user will have to log in again and refresh their tokens for any database connections that use OAuth.
- Looker application API keys are not exported. All users will lose access to all existing API keys since they won't be part of the imported package
- If you export and import into a Looker (Google Cloud core) instance that uses a different networking setup than the instance that created the export, you may need to configure your connections to external services differently.
- If moving an export from an instance in one Google Cloud project to an instance in a different project, IAM permissions to provide users with access to the instance need to be set in the new project.
Required role
    
      To get the permissions that
      you need to import or export Looker (Google Cloud core) instance data,
    
      ask your administrator to grant you the
    
  
  
    
      Looker Admin  (roles/looker.admin)
     IAM role on the project in which the instance was created.
  
  
  
  
  For more information about granting roles, see Manage access to projects, folders, and organizations.
  
  
You might also be able to get the required permissions through custom roles or other predefined roles.
Exporting your Looker (Google Cloud core) instance data to a Cloud Storage bucket
The following sections explain how to export your instance data.
Required objects and permissions for exporting to a Cloud Storage bucket
- A Looker service account. If you used the Google Cloud CLI CLI, Terraform, or the API to create your Looker (Google Cloud core) instance, and you have not yet created a Looker service account, you will need to create one.
- A Cloud Storage bucket with the storage.objects.createpermission assigned to the Looker service account. The Storage Object Creator (roles/storage.objectCreator) IAM role includes this permission, so you can alternatively assign that role to the Looker service account.
- A customer-managed encryption key (CMEK). This CMEK is specific to the export and import process and is different from a CMEK used for encrypting your instance data. The CMEK cloudkms.cryptoKeyVersions.useToEncryptpermission must be assigned to the Looker service account. The Cloud KMS CryptoKey Encrypter (roles/cloudkms.cryptoKeyEncrypter) role includes this permission, so you can alternatively assign that role to the Looker service account.
Exporting to a Cloud Storage bucket
To export your data, select one of the following options:
console
- Go to the Looker page in the Google Cloud console. 
- On the Select organization drop-down list at the top of the page, select the organization resource that includes the Looker (Google Cloud core) instance for which you want to export data. 
- Click the name of the instance for which you want to export data. 
- Click Export. 
- In the Export Bucket field, specify the bucket location where you want the export artifact to be created. You can either enter the path in the input field as - <bucket_name>/<folder_name>or browse to select the appropriate location in the bucket.
- In the Select a customer-managed key field, select the CMEK to be used for encrypting the export artifact. 
- Click EXPORT. 
gcloud
gcloud looker instances export INSTANCE_NAME \ --target-gcs-uri='gs://BUCKET_NAME/FOLDER_NAME' \ --kms-key=KMS_KEY_ID
Replace the following:
- INSTANCE_NAME: a name for your Looker (Google Cloud core) instance; it is not associated with the instance URL
- BUCKET_NAME: the Cloud Storage bucket location where you want the export artifact to be created
- FOLDER_NAME: the folder you want the export artifact to be placed in within the Cloud Storage bucket
- KMS_KEY_ID: the full path to the import- and export-specific CMEK key ID
Importing your data from a Cloud Storage bucket to a Looker (Google Cloud core) instance
The following sections explain how to import your instance data.
Required permissions for importing from a Cloud Storage bucket
- A Looker service account. If you used the Google Cloud CLI, Terraform, or the API to create your Looker (Google Cloud core) instance, and you have not already created a Looker service account, you will need to create one.
- Grant the storage.objects.getpermission to the Looker service account. The Storage Object Viewer (roles/storage.objectViewer) IAM role includes this permission, so you can alternatively assign that role to the Looker service account.
- The cloudkms.cryptoKeyVersions.useToDecryptpermission must be assigned to the Looker service account. The Cloud KMS CryptoKey Decrypter (roles/cloudkms.cryptoKeyDecrypter) role includes this permission, so you can alternatively assign that role to the Looker service account.
Importing from a Cloud Storage bucket
To import your data, select one of the following options:
console
- Go to the Looker page in the Google Cloud console. 
- On the Select organization drop-down list at the top of the page, select the organization resource that includes the Looker (Google Cloud core) instance where you want to import data. 
- Click the name of the instance where you want to import data. 
- Click IMPORT. 
- In the Import Bucket field, either enter the path or browse to the Cloud Storage location where you exported your data. Select the folder containing the - metadata.jsonfile and other files.
- Click IMPORT. 
gcloud
gcloud looker instances import INSTANCE_NAME \ --source-gcs-uri='gs://BUCKET_NAME/FOLDER_NAME'
Replace the following:
- INSTANCE_NAME: a name for your Looker (Google Cloud core) instance; it is not associated with the instance URL
- BUCKET_NAME: the Cloud Storage bucket location where the- metadata.jsonfile and other files are located
- FOLDER_NAME: the folder in which the- metadata.jsonfile and other files are located
After an import, Looker (Google Cloud core) users will be prompted to re-authenticate to any BigQuery or Snowflake database connections that use OAuth for individual user authentication. That is because a Looker (Google Cloud core) export doesn't retain OAuth access or refresh tokens for individual users' database connections.
Users can re-authenticate to their databases with one of the following methods:
- Follow the Log in prompt that appears when they view an Explore or a dashboard that uses an individual OAuth database connection.
- Go to their Account page and select Log in for each of the databases under the OAuth Connection Credentials heading.
Any automated schedules or alerts that are owned by a single user and that reference an OAuth connection will break until that user logs in with their OAuth credentials.
Troubleshooting the export or import of Looker (Google Cloud core) data
This section describes how to remediate error conditions that could cause an export or import process to fail.
Errors during export
- Ensure that you have granted the Looker service account the - storage.objects.createpermission or the Storage Object Creator (- roles/storage.objectCreator) IAM role to the Cloud Storage bucket.
- Ensure that you have granted the Looker service account the - cloudkms.cryptoKeyVersions.useToEncryptpermission or the Cloud KMS CryptoKey Encrypter (- roles/cloudkms.cryptoKeyEncrypter) role to the Customer-managed encryption key (CMEK) that you created.
- Ensure that the given Cloud Storage location doesn't have any files from a previous export operation in it before you export your data. If there are any pre-existing files, remove them first. 
- You cannot use a Cloud Storage bucket that has Requester Pays enabled. 
Import errors
- Ensure that you have granted the Looker service account the - storage.objects.getpermission or the Storage Object Viewer (- roles/storage.objectViewer) IAM role to the Cloud Storage bucket.
- Ensure that you have granted the Looker service account the - cloudkms.cryptoKeyVersions.useToDecryptpermission or the Cloud KMS CryptoKey Decrypter (- roles/cloudkms.cryptoKeyDecrypter) role to the Customer-managed encryption key (CMEK) that you created.
- Importing can fail due to version incompatibility between the target instance and the export instance, as follows: - The target instance has a Looker minor version that is less than the Looker version of exported data. For example, the target instance is on Looker 23.5.X, but the export was created from an instance on Looker version 23.6.X.
- The minor version of the instance that created the export data is behind the Looker version of the target instance by more than one release. For example, the target instance is on Looker 23.6.X, but the export was created from an instance on Looker version 23.4.X.
 - In this case, upgrade either the export instance or the target instance so that both instances are running the same Looker version.