Table: aws_dms_replication_task - Query AWS DMS Replication Tasks using SQL
AWS Database Migration Service (DMS) Replication Tasks play a critical role in managing data migrations between source and target databases. These tasks facilitate the entire migration process, supporting various migration types, including full load migrations, ongoing replication to synchronize source and target databases and change data capture (CDC) for applying data modifications.
The aws_dms_replication_task
table in Steampipe allows for in-depth analysis of replication tasks, providing details such as task identifiers, status, migration types, settings, and endpoint ARNs. This table proves essential for database administrators and DevOps engineers overseeing database migrations, offering comprehensive insights into each task's configuration, progress, and performance.
Examples
Basic Info
Query to fetch basic details about DMS replication tasks.
select replication_task_identifier, arn, migration_type, status, replication_task_creation_datefrom aws_dms_replication_task;
select replication_task_identifier, arn, migration_type, status, replication_task_creation_datefrom aws_dms_replication_task;
Tasks with specific migration types
List replication tasks by a specific migration type, such as 'full-load'.
select replication_task_identifier, migration_type, statusfrom aws_dms_replication_taskwhere migration_type = 'full-load';
select replication_task_identifier, migration_type, statusfrom aws_dms_replication_taskwhere migration_type = 'full-load';
Replication tasks with failures
Identify replication tasks that have failed, focusing on the last failure message.
select replication_task_identifier, status, last_failure_messagefrom aws_dms_replication_taskwhere status = 'failed';
select replication_task_identifier, status, last_failure_messagefrom aws_dms_replication_taskwhere status = 'failed';
Task performance statistics
Examine detailed performance statistics of replication tasks.
select replication_task_identifier, status, replication_task_stats -> 'ElapsedTimeMillis' as elapsed_time_millis, replication_task_stats -> 'FreshStartDate' as fresh_start_date, replication_task_stats -> 'FullLoadFinishDate' as full_load_finish_date, replication_task_stats -> 'FullLoadProgressPercent' as full_load_progress_percent, replication_task_stats -> 'FullLoadStartDate' as full_load_start_date, replication_task_stats -> 'StartDate' as start_date, replication_task_stats -> 'StopDate' as stop_date, replication_task_stats -> 'TablesErrored' as tables_errored, replication_task_stats -> 'TablesLoaded' as tables_loaded, replication_task_stats -> 'TablesLoading' as tables_loading, replication_task_stats -> 'TablesQueued' as tables_queuedfrom aws_dms_replication_task;
select replication_task_identifier, status, json_extract(replication_task_stats, '$.ElapsedTimeMillis') as elapsed_time_millis, json_extract(replication_task_stats, '$.FreshStartDate') as fresh_start_date, json_extract(replication_task_stats, '$.FullLoadFinishDate') as full_load_finish_date, json_extract( replication_task_stats, '$.FullLoadProgressPercent' ) as full_load_progress_percent, json_extract(replication_task_stats, '$.FullLoadStartDate') as full_load_start_date, json_extract(replication_task_stats, '$.StartDate') as start_date, json_extract(replication_task_stats, '$.StopDate') as stop_date, json_extract(replication_task_stats, '$.TablesErrored') as tables_errored, json_extract(replication_task_stats, '$.TablesLoaded') as tables_loaded, json_extract(replication_task_stats, '$.TablesLoading') as tables_loading, json_extract(replication_task_stats, '$.TablesQueued') as tables_queuedfrom aws_dms_replication_task;
Get replication instance details
Retrieve replication instance details for the tasks.
select t.replication_task_identifier, t.arn as task_arn, i.replication_instance_class, i.engine_version, i.publicly_accessible, i.dns_name_serversfrom aws_dms_replication_task t join aws_dms_replication_instance i on t.replication_instance_arn = i.arn;
select t.replication_task_identifier, t.arn as task_arn, i.replication_instance_class, i.engine_version, i.publicly_accessible, i.dns_name_serversfrom aws_dms_replication_task as t join aws_dms_replication_instance as i on t.replication_instance_arn = i.arn;
List source endpoint tasks
Query to list tasks associated with source endpoints.
select replication_task_identifier, source_endpoint_arn, statusfrom aws_dms_replication_taskwhere endpoint_type = 'source';
select replication_task_identifier, source_endpoint_arn, statusfrom aws_dms_replication_taskwhere endpoint_type = 'source';
Endpoint type count
Count tasks by endpoint type (source or target).
select endpoint_type, count(*) as task_countfrom aws_dms_replication_taskgroup by endpoint_type;
select endpoint_type, count(*) as task_countfrom aws_dms_replication_taskgroup by endpoint_type;
Control examples
- AWS Foundational Security Best Practices > DMS > 7 DMS replication tasks for the target database should have logging enabled
- AWS Foundational Security Best Practices > DMS > 8 DMS replication tasks for the source database should have logging enabled
- DMS replication tasks for the source database should have logging enabled
- DMS replication tasks for the target database should have logging enabled
Schema for aws_dms_replication_task
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form. | |
account_id | text | =, !=, ~~, ~~*, !~~, !~~* | The AWS Account ID in which the resource is located. |
akas | jsonb | Array of globally unique identifier strings (also known as) for the resource. | |
arn | text | = | The Amazon Resource Name (ARN) of the replication task. |
cdc_start_position | text | Indicates when you want a change data capture (CDC) operation to start. | |
cdc_stop_position | text | Indicates when you want a change data capture (CDC) operation to stop. | |
last_failure_message | text | The last error (failure) message generated for the replication task. | |
migration_type | text | = | The type of migration. |
partition | text | The AWS partition in which the resource is located (aws, aws-cn, or aws-us-gov). | |
recovery_checkpoint | text | Indicates the last checkpoint that occurred during a change data capture (CDC) operation. | |
region | text | The AWS Region in which the resource is located. | |
replication_instance_arn | text | = | The Amazon Resource Name (ARN) of the replication instance. |
replication_task_creation_date | timestamp with time zone | The date the replication task was created. | |
replication_task_identifier | text | = | The user-assigned replication task identifier or name. |
replication_task_settings | jsonb | The settings for the replication task. | |
replication_task_start_date | timestamp with time zone | The date the replication task is scheduled to start. | |
replication_task_stats | jsonb | The statistics for the task, including elapsed time, tables loaded, and table errors. | |
source_endpoint_arn | text | = | The Amazon Resource Name (ARN) that uniquely identifies the endpoint. |
sp_connection_name | text | =, !=, ~~, ~~*, !~~, !~~* | Steampipe connection name. |
sp_ctx | jsonb | Steampipe context in JSON form. | |
status | text | The status of the replication task. | |
stop_reason | text | The reason the replication task was stopped. | |
table_mappings | text | Table mappings specified in the task. | |
tags | jsonb | A map of tags for the resource. | |
tags_src | jsonb | A list of tags currently associated with the replication instance. | |
target_endpoint_arn | text | = | The ARN that uniquely identifies the endpoint. |
target_replication_instance_arn | text | The ARN of the replication instance to which this task is moved in response to running the MoveReplicationTask operation. | |
task_data | text | Supplemental information that the task requires to migrate the data for certain source and target endpoints. | |
title | text | Title of the resource. |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- aws
You can pass the configuration to the command with the --config
argument:
steampipe_export_aws --config '<your_config>' aws_dms_replication_task