Overview
Database Migration Service uses migration jobs to migrate data from your source database instance to the destination database instance.
Creating a migration job for an existing destination instance includes:
- Defining settings for the migration job
- Selecting the source database connection profile
- Selecting the existing destination database instance
- Demoting the existing instance to convert it into a read replica
- Setting up connectivity between the source and destination database instances
- Testing the migration job to ensure that the connection information you provided for the job is valid
There are certain limitations that you should consider when you want to migrate to a destination instance created outside of Database Migration Service. For more information, see Known limitations.
Database Migration Service wizard helps you create a migration job. This wizard consists of the following panes: Get started, Define a source, Create a destination, Define connectivity method, Configure migration databases, and Test and create migration job. Information on how to populate each pane is provided in the following sections of this page.
Create a migration job by using the Google Cloud console
Define settings for the migration job
- Go to the Migration jobs in the Google Cloud console. 
- Click Create migration job at the top of the page. 
- Provide a name for the migration job. Choose a friendly name that helps you identify the migration job. Don't include sensitive or personally identifiable information in the job name. 
- Keep the auto-generated Migration job ID. 
- Select the source database engine. 
- Select AlloyDB for PostgreSQL as the destination engine. 
- Select the destination region for your migration. This region must be the same as the one where your destination database is located. After you choose the destination region, this selection can't be changed. 
- Choose Continuous (snapshot + ongoing changes) as the migration job type. 
- In the Before you continue, review the prerequisites section, click Open to view automatically generated instructions that can help guide you through preparing your source database for the migration. It's best to complete these prerequisites at this step, but you can complete them at any time before you test, or start, the migration job. For more information, see Configure your source. 
- Click Save and continue. 
Specify information about the source connection profile
- 
    If you have created a connection profile, then select it from the list of existing connection profiles. If you haven't created a connection profile, then create one by clicking Create a connection profile at the bottom of the drop-down list, and then perform the same steps as in Create a source connection profile. It is recommended to create a designated connection profile for your AlloyDB migration. 
- In the Customize data dump configurations section,
  click Show data dump configurations.
  The speed of data dump parallelism is related to the amount of load on your source database. You can use the following settings: - Optimal (recommended): Balanced performance with optimal load on the source database.
- Maximum: Provides the highest dump speeds, but might cause increased load on the source database.
- Minimum: Takes the lowest amount of compute resources on the source database, but might have slower dump throughput.
 If you want to use adjusted data dump parallelism settings, make sure to increase the max_replication_slots,max_wal_senders, andmax_worker_processesparameters on your source database. You can verify your configuration by running the migration job test at the end of migration job creation.
- Click Save and continue.
Select the destination instance
- From the Type of destination cluster menu, select Existing cluster.
- In the Select destination cluster section, select your destination cluster.
- Review the information about your cluster, and click Select and continue.
- To migrate to an existing destination database, Database Migration Service demotes the target instance and converts it to a replica. To signify that the demotion can be safely performed, in the confirmation window, enter the destination instance identifier.
- Click Confirm and continue.
Set up connectivity between the source and destination database instances
- From the Connectivity method drop-down menu, select a network connectivity method. This method defines how the newly created AlloyDB cluster will connect to the source database. Current network connectivity methods include IP allowlist, VPC peering, Private Service Connect interfaces, reverse SSH tunnel, and TCP proxy through a cloud-hosted VM.
- If you select the IP allowlist network connectivity method, you need to specify the outgoing IP address of your destination instance. Copy the outgoing IP addresses for both the primary and the secondary instance and use them to configure the network firewall for your source database server and in the pg_hba.conffile, so that the source can accept connections from these addresses.
- If you select the reverse SSH tunnel network connectivity method, then select the Compute Engine VM instance that will host the tunnel. - After specifying the instance, Google will provide a script that performs the steps to set up the tunnel between the source and destination databases. You'll need to run the script in the Google Cloud CLI. - Run the commands from a machine that has connectivity to both the source database and to Google Cloud. 
- If you use one of the private IP connectivity methods, select VPC peering or PSC interface.
- If you select the VPC peering network connectivity method, then select the VPC network where the source database resides. The Cloud SQL instance will be updated to connect to this network.
- If you select the TCP Proxy via cloud-hosted VM connectivity method, then enter the required details for the new Compute Engine VM instance that will host the TCP proxy. - After specifying the details, the Google Cloud console will provide a script that performs the steps to set up the proxy between the source and destination databases. You'll need to run the script on a machine with an updated Google Cloud CLI. - After running the script, it will output the newly created VM's private IP. Enter the IP and click Configure & continue. 
- After selecting the network connectivity method and providing any additional information for the method, click CONFIGURE & CONTINUE.
Configure migration databases
You can select the databases that you want to migrate.
- From the Databases to migrate list, select one of the following options:
- All databases: Selects all databases that exist on the source.
- Specific databases: Lets you select specific databases from all databases that exist on the source.
 
- If you want to migrate specific databases, you can filter the list that appears and select the databases that you want Database Migration Service to migrate into your destination. - If the list doesn't appear and a database discovery error is displayed, click Reload. If database discovery fails, the job migrates all databases. You can continue with creating a migration job and fix connectivity errors later. 
- Click Save and continue.
Test and create the migration job
On this final step, review the summary of the migration job settings, source, destination, and connectivity method, and then test the validity of the migration job setup. If any issues are encountered, then you can modify the migration job's settings. Not all settings are editable.
- Click TEST JOB to verify that: - The source database has been configured correctly, based on the prerequisites.
- The source and destination instances can communicate with each other.
- Any updates to private IP addresses needed on the destination are done.
- The migration job is valid, and the source and destination versions are compatible.
 - If the test fails, then you can address the problem in the appropriate part of the flow, and return to re-test. - The migration job can be created even if the test fails, but after the job is started, it may fail at some point during the run. 
- Click CREATE & START JOB to create the migration job and start it immediately, or click CREATE JOB to create the migration job without immediately starting it. - If the job isn't started at the time that it's created, then it can be started from the Migration jobs page by clicking START. - Regardless of when the migration job starts, your organization is charged for the existence of the destination instance. - When you start the migration job, Database Migration Service begins the full dump, briefly locking the source database. If your source is in Amazon RDS or Amazon Aurora, Database Migration Service additionally requires a short (approximately under a minute) write downtime at the start of the migration. For more information, see Data dump parallelism considerations. 
- The migration job is added to the migration jobs list and can be viewed directly. 
- Proceed to Review the migration job. 
Create a migration job by using Google Cloud CLI
When you migrate to an existing instance by using Google Cloud CLI, you must manually create the connection profile for the destination instance. This isn't required when you use the Google Cloud console, as Database Migration Service takes care of creating and removing the destination connection profile for you.
Before you begin
Before you use gcloud CLI to create a migration job to an existing destination database instance, make sure you:
- Create your destination database instance.
- Prepare your source database instance. See:
- Configure your source
- Create the source connection profile (Source connection profile identifier is required to create a migration job.)
- Configure connectivity
 
Create destination connection profile
Create the destination connection profile for your existing destination instance
by running the
gcloud database-migration connection-profiles create
command:
This sample uses the optional --no-async flag so that all operations
are performed synchronously. This means that some commands might take
a while to complete. You can skip the --no-async flag to run commands asynchronously.
If you do, you need to use the
gcloud database-migration operations describe command to verify if your operation
is successful.
Before using any of the command data below, make the following replacements:
- CONNECTION_PROFILE_ID with a machine-readable identifier for your connection profile.
- REGION with the identifier of the region where you want to save the connection profile.
- DESTINATION_INSTANCE_ID with the instance identifier of your destination instance.
- (Optional) CONNECTION_PROFILE_NAME with a human-readable name for your connection profile. This value is displayed in the Google Cloud console.
Execute the following command:
Linux, macOS, or Cloud Shell
gcloud database-migration connection-profiles \ create postgresql CONNECTION_PROFILE_ID \ --no-async \ --alloydb-cluster=DESTINATION_INSTANCE_ID \ --region=REGION \ --display-name=CONNECTION_PROFILE_NAME
Windows (PowerShell)
gcloud database-migration connection-profiles ` create postgresql CONNECTION_PROFILE_ID ` --no-async ` --alloydb-cluster=DESTINATION_INSTANCE_ID ` --region=REGION ` --display-name=CONNECTION_PROFILE_NAME
Windows (cmd.exe)
gcloud database-migration connection-profiles ^ create postgresql CONNECTION_PROFILE_ID ^ --no-async ^ --alloydb-cluster=DESTINATION_INSTANCE_ID ^ --region=REGION ^ --display-name=CONNECTION_PROFILE_NAME
You should receive a response similar to the following:
Waiting for connection profile [CONNECTION_PROFILE_ID] to be created with [OPERATION_ID] Waiting for operation [OPERATION_ID] to complete...done. Created connection profile CONNECTION_PROFILE_ID [OPERATION_ID]
Create the migration job
This sample uses the optional --no-async flag so that all operations
are performed synchronously. This means that some commands might take
a while to complete. You can skip the --no-async flag to run commands asynchronously.
If you do, you need to use the
gcloud database-migration operations describe command to verify if your operation
is successful.
Before using any of the command data below, make the following replacements:
- MIGRATION_JOB_ID with a machine-readable identifier for your migration job. You use this value to work with migration jobs by using Database Migration Service Google Cloud CLI commands or API.
- REGION with the region identifier where you want to save the migration job.
- MIGRATION_JOB_NAME with a human-readable name for your migration job. This value is displayed in Database Migration Service in the Google Cloud console.
- SOURCE_CONNECTION_PROFILE_ID with a machine-readable identifier of the source connection profile.
- DESTINATION_CONNECTION_PROFILE_ID with a machine-readable identifier of the destination connection profile.
- Optional: Database Migration Service migrates all databases in your source by default. If you want to migrate only specific databases, use the - --databases-filterflag and specify their identifiers as a comma-separated list.- For example: - --databases-filter=my-business-database,my-other-database- You can later edit migration jobs that you created with the - --database-filter flagby using the- gcloud database-migration migration-jobs updatecommand.
Execute the following command:
Linux, macOS, or Cloud Shell
gcloud database-migration migration-jobs \ create MIGRATION_JOB_ID \ --no-async \ --region=REGION \ --display-name=MIGRATION_JOB_NAME \ --source=SOURCE_CONNECTION_PROFILE_ID \ --destination=DESTINATION_CONNECTION_PROFILE_ID \ --type=CONTINUOUS \
Windows (PowerShell)
gcloud database-migration migration-jobs ` create MIGRATION_JOB_ID ` --no-async ` --region=REGION ` --display-name=MIGRATION_JOB_NAME ` --source=SOURCE_CONNECTION_PROFILE_ID ` --destination=DESTINATION_CONNECTION_PROFILE_ID ` --type=CONTINUOUS `
Windows (cmd.exe)
gcloud database-migration migration-jobs ^ create MIGRATION_JOB_ID ^ --no-async ^ --region=REGION ^ --display-name=MIGRATION_JOB_NAME ^ --source=SOURCE_CONNECTION_PROFILE_ID ^ --destination=DESTINATION_CONNECTION_PROFILE_ID ^ --type=CONTINUOUS ^
You should receive a response similar to the following:
Waiting for migration job [MIGRATION_JOB_ID] to be created with [OPERATION_ID] Waiting for operation [OPERATION_ID] to complete...done. Created migration job MIGRATION_JOB_ID [OPERATION_ID]
Demote the destination database
Database Migration Service requires that the destination database instance
works as a read replica for the time of migration. Before you start the
migration job, run the
gcloud database-migration migration-jobs demote-destination
command to demote the destination database instance.
Before using any of the command data below, make the following replacements:
- MIGRATION_JOB_ID with
  your migration job identifier.
    If you don't know the identifier, you can use the gcloud database-migration migration-jobs listcommand to list all migration jobs in a given region and view their identifiers.
- REGION with the identifier of the region where your connection profile is saved.
Execute the following command:
Linux, macOS, or Cloud Shell
gcloud database-migration migration-jobs \ demote-destination MIGRATION_JOB_ID \ --region=REGION
Windows (PowerShell)
gcloud database-migration migration-jobs ` demote-destination MIGRATION_JOB_ID ` --region=REGION
Windows (cmd.exe)
gcloud database-migration migration-jobs ^ demote-destination MIGRATION_JOB_ID ^ --region=REGION
Result
The action is performed in an asynchronous manner. As such, this command returns an Operation entity that represents a long-running operation:
done: false metadata: '@type': type.googleapis.com/google.cloud.clouddms.v1.OperationMetadata apiVersion: v1 createTime: '2024-02-20T12:20:24.493106418Z' requestedCancellation: false target: MIGRATION_JOB_ID verb: demote-destination name: OPERATION_ID
To see if your operation is successful, you can query the returned operation object, or check the status of the migration job:
- Use the 
  gcloud database-migration migration-jobs describecommand to view the status of the migration job.
- Use the 
  gcloud database-migration operations describewith the OPERATION_ID to see the status of the operation itself.
Manage migration jobs
At this point, your migration job is configured and connected to your destination database instance. You can manage it by using the following operations:
- Optional: Verify the migration job. 
 We recommend that you first verify your migration job by running the- gcloud database-migration migration-jobs verifycommand.- For more information, expand the following section: - gcloud database-migration migration-jobs verify- Before using any of the command data below, make the following replacements: - MIGRATION_JOB_ID with
  your migration job identifier.
    If you don't know the identifier, you can use the gcloud database-migration migration-jobs listcommand to list all migration jobs in a given region and view their identifiers.
- REGION with the identifier of the region where your connection profile is saved.
 - Execute the following command: - Linux, macOS, or Cloud Shell- gcloud database-migration migration-jobs \ verify MIGRATION_JOB_ID \ --region=REGION - Windows (PowerShell)- gcloud database-migration migration-jobs ` verify MIGRATION_JOB_ID ` --region=REGION - Windows (cmd.exe)- gcloud database-migration migration-jobs ^ verify MIGRATION_JOB_ID ^ --region=REGION - Result- The action is performed in an asynchronous manner. As such, this command returns an Operation entity that represents a long-running operation: - done: false metadata: '@type': type.googleapis.com/google.cloud.clouddms.v1.OperationMetadata apiVersion: v1 createTime: '2024-02-20T12:20:24.493106418Z' requestedCancellation: false target: MIGRATION_JOB_ID verb: verify name: OPERATION_ID - To see if your operation is successful, you can query the returned operation object, or check the status of the migration job: - Use the 
  gcloud database-migration migration-jobs describecommand with the MIGRATION_JOB_ID to view the status of the migration job.
- Use the 
  gcloud database-migration operations describecommand with the OPERATION_ID to see the status of the operation itself.
 
- MIGRATION_JOB_ID with
  your migration job identifier.
    
- Optional: Retrieve information about databases selected for migration. 
 When you migrate specific databases, Database Migration Service needs to retrieve the details about the databases that you selected for the migration job by using the- --database-filterflag.- Before you start the migration job, run the - gcloud database-migration migration-jobs fetch-source-objectscommand.- For more information, expand the following section: - gcloud database-migration migration-jobs fetch-source-objects- Before using any of the command data below, make the following replacements: - MIGRATION_JOB_ID with
  your migration job identifier.
    If you don't know the identifier, you can use the gcloud database-migration migration-jobs listcommand to list all migration jobs in a given region and view their identifiers.
- REGION with the identifier of the region where your connection profile is saved.
 - Execute the following command: - Linux, macOS, or Cloud Shell- gcloud database-migration migration-jobs \ fetch-source-objects MIGRATION_JOB_ID \ --region=REGION - Windows (PowerShell)- gcloud database-migration migration-jobs ` fetch-source-objects MIGRATION_JOB_ID ` --region=REGION - Windows (cmd.exe)- gcloud database-migration migration-jobs ^ fetch-source-objects MIGRATION_JOB_ID ^ --region=REGION - Result- The output is similar to the following: - Waiting for migration job MIGRATION_JOB_ID to fetch source objects with OPERATION_ID Waiting for operation OPERATION_ID to complete...done. SOURCE_OBJECT STATE PHASE ERROR {'database': 'DATABASE_NAME', 'type': 'DATABASE'} NOT_SELECTED PHASE_UNSPECIFIED {'database': 'DATABASE_NAME', 'type': 'DATABASE'} STOPPED CDC {'code': 1, 'message': 'Internal error'}- To see if your operation is successful, you can query the returned operation object, or check the status of the migration job: - Use the 
  gcloud database-migration migration-jobs describecommand with the MIGRATION_JOB_ID to view the status of the migration job.
- Use the 
  gcloud database-migration operations describecommand with the OPERATION_ID to see the status of the operation itself.
 
- MIGRATION_JOB_ID with
  your migration job identifier.
    
- Start the migration job. 
 Start the migration job by running the- gcloud database-migration migration-jobs startcommand.- For more information, expand the following section: - gcloud database-migration migration-jobs start- Before using any of the command data below, make the following replacements: - MIGRATION_JOB_ID with
  your migration job identifier.
    If you don't know the identifier, you can use the gcloud database-migration migration-jobs listcommand to list all migration jobs in a given region and view their identifiers.
- REGION with the identifier of the region where your connection profile is saved.
 - Execute the following command: - Linux, macOS, or Cloud Shell- gcloud database-migration migration-jobs \ start MIGRATION_JOB_ID \ --region=REGION - Windows (PowerShell)- gcloud database-migration migration-jobs ` start MIGRATION_JOB_ID ` --region=REGION - Windows (cmd.exe)- gcloud database-migration migration-jobs ^ start MIGRATION_JOB_ID ^ --region=REGION - Result- The action is performed in an asynchronous manner. As such, this command returns an Operation entity that represents a long-running operation: - done: false metadata: '@type': type.googleapis.com/google.cloud.clouddms.v1.OperationMetadata apiVersion: v1 createTime: '2024-02-20T12:20:24.493106418Z' requestedCancellation: false target: MIGRATION_JOB_ID verb: start name: OPERATION_ID - To see if your operation is successful, you can query the returned operation object, or check the status of the migration job: - Use the 
  gcloud database-migration migration-jobs describecommand with the MIGRATION_JOB_ID to view the status of the migration job.
- Use the 
  gcloud database-migration operations describecommand with the OPERATION_ID to see the status of the operation itself.
 
- MIGRATION_JOB_ID with
  your migration job identifier.
    
Promote the migration job
Once the migration reaches the Change Data Capture (CDC) phase,
you can promote the destination database
instance from a read replica to a standalone instance.
Run the gcloud database-migration migration-jobs promote
command:
Before using any of the command data below, make the following replacements:
- MIGRATION_JOB_ID with
  your migration job identifier.
    If you don't know the identifier, you can use the gcloud database-migration migration-jobs listcommand to list all migration jobs in a given region and view their identifiers.
- REGION with the identifier of the region where your connection profile is saved.
Execute the following command:
Linux, macOS, or Cloud Shell
gcloud database-migration migration-jobs \ promote MIGRATION_JOB_ID \ --region=REGION
Windows (PowerShell)
gcloud database-migration migration-jobs ` promote MIGRATION_JOB_ID ` --region=REGION
Windows (cmd.exe)
gcloud database-migration migration-jobs ^ promote MIGRATION_JOB_ID ^ --region=REGION
Result
The action is performed in an asynchronous manner. As such, this command returns an Operation entity that represents a long-running operation:
done: false metadata: '@type': type.googleapis.com/google.cloud.clouddms.v1.OperationMetadata apiVersion: v1 createTime: '2024-02-20T12:20:24.493106418Z' requestedCancellation: false target: MIGRATION_JOB_ID verb: start name: OPERATION_ID
- Use the 
  gcloud database-migration migration-jobs describecommand with the MIGRATION_JOB_ID to view the status of the migration job.
- Use the 
  gcloud database-migration operations describecommand with the OPERATION_ID to see the status of the operation itself.
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-10-16 UTC.