steampipe plugin install aws

Table: aws_dms_endpoint - Query AWS DMS Endpoints using SQL

AWS Database Migration Service (DMS) Endpoints are a pivotal component within AWS DMS, delineating the connection details for source or target databases involved in migration tasks. These endpoints are essential for defining the data's origin (source) and destination (target).

Table Usage Guide

The aws_dms_endpoint table in Steampipe allows you to query connection-specific information, such as the endpoint identifier, ARN, database name, endpoint type, and the database engine details. This table is invaluable for DevOps engineers and database administrators overseeing database migrations, as it facilitates the monitoring and management of endpoint configurations and ensures the smooth execution of migration tasks.

Examples

Basic info

Retrieve basic information about AWS DMS Endpoint, including their identifiers, ARNs, certificate, database, endpoint type, engine name, and regions.

select
endpoint_identifier,
arn,
certificate_arn,
database_name,
endpoint_type,
engine_display_name,
engine_name
from
aws_dms_endpoint;
select
endpoint_identifier,
arn,
certificate_arn,
database_name,
endpoint_type,
engine_display_name,
engine_name
from
aws_dms_endpoint;

List source endpoints

Identify all source endpoints in AWS DMS, showcasing their identifiers, ARNs, display names, types, and engine names.

select
endpoint_identifier,
arn,
engine_display_name,
endpoint_type,
engine_name
from
aws_dms_endpoint
where
endpoint_type = 'SOURCE';
select
endpoint_identifier,
arn,
engine_display_name,
endpoint_type,
engine_name
from
aws_dms_endpoint
where
endpoint_type = 'SOURCE';

List MySQL endpoints

Retrieve a comprehensive list of AWS DMS endpoints configured for MySQL databases, including their identifiers, ARNs, engine names, creation times, and MySQL-specific settings."

select
endpoint_identifier,
arn,
engine_name,
instance_create_time,
my_sql_settings
from
aws_dms_endpoint
where
engine_name = 'mysql';
select
endpoint_identifier,
arn,
engine_name,
instance_create_time,
my_sql_settings
from
aws_dms_endpoint
where
engine_name = 'mysql';

List endpoints that have SSL enabled

Display all AWS DMS endpoints with SSL encryption enabled, detailing their identifiers, KMS key IDs, server names, service access role ARNs, and SSL modes."

select
endpoint_identifier,
kms_key_id,
server_name,
service_access_role_arn,
ssl_mode
from
aws_dms_endpoint
where
ssl_mode <> 'none';
select
endpoint_identifier,
kms_key_id,
server_name,
service_access_role_arn,
ssl_mode
from
aws_dms_endpoint
where
ssl_mode <> 'none';

Get MySQL setting details for MySQL endpoints

Extract detailed MySQL settings for AWS DMS endpoints configured for MySQL, including connection scripts, metadata settings, database names, and other MySQL-specific configurations.

select
endpoint_identifier,
arn,
my_sql_settings ->> 'AfterConnectScript' as after_connect_script,
(
my_sql_settings ->> 'CleanSourceMetadataOnMismatch'
) :: boolean as clean_source_metadata_on_mismatch,
my_sql_settings ->> 'DatabaseName' as database_name,
(my_sql_settings ->> 'EventsPollInterval') :: integer as events_poll_interval,
(my_sql_settings ->> 'ExecuteTimeout') :: integer as execute_timeout,
(my_sql_settings ->> 'MaxFileSize') :: integer as max_file_size,
(my_sql_settings ->> 'ParallelLoadThreads') :: integer as parallel_load_threads,
my_sql_settings ->> 'Password' as password,
(my_sql_settings ->> 'Port') :: integer as port,
my_sql_settings ->> 'SecretsManagerAccessRoleArn' as secrets_manager_access_role_arn,
my_sql_settings ->> 'SecretsManagerSecretId' as secrets_manager_secret_id,
my_sql_settings ->> 'ServerName' as server_name,
my_sql_settings ->> 'ServerTimezone' as server_timezone,
my_sql_settings ->> 'TargetDbType' as target_db_type,
my_sql_settings ->> 'Username' as username
from
aws_dms_endpoint
where
engine_name = 'mysql';
select
endpoint_identifier,
arn,
my_sql_settings ->> 'AfterConnectScript' as after_connect_script,
cast(
json_extract(
my_sql_settings,
'$.CleanSourceMetadataOnMismatch'
) as boolean
) as clean_source_metadata_on_mismatch,
my_sql_settings ->> 'DatabaseName' as database_name,
cast(
json_extract(my_sql_settings, '$.EventsPollInterval') as integer
) as events_poll_interval,
cast(
json_extract(my_sql_settings, '$.ExecuteTimeout') as integer
) as execute_timeout,
cast(
json_extract(my_sql_settings, '$.MaxFileSize') as integer
) as max_file_size,
cast(
json_extract(my_sql_settings, '$.ParallelLoadThreads') as integer
) as parallel_load_threads,
my_sql_settings ->> 'Password' as password,
cast(json_extract(my_sql_settings, '$.Port') as integer) as port,
my_sql_settings ->> 'SecretsManagerAccessRoleArn' as secrets_manager_access_role_arn,
my_sql_settings ->> 'SecretsManagerSecretId' as secrets_manager_secret_id,
my_sql_settings ->> 'ServerName' as server_name,
my_sql_settings ->> 'ServerTimezone' as server_timezone,
my_sql_settings ->> 'TargetDbType' as target_db_type,
my_sql_settings ->> 'Username' as username
from
aws_dms_endpoint
where
engine_name = 'mysql';

Schema for aws_dms_endpoint

NameTypeOperatorsDescription
_ctxjsonbSteampipe context in JSON form.
account_idtext=, !=, ~~, ~~*, !~~, !~~*The AWS Account ID in which the resource is located.
akasjsonbArray of globally unique identifier strings (also known as) for the resource.
arntext=The Amazon Resource Name (ARN) string that uniquely identifies the endpoint.
certificate_arntextThe Amazon Resource Name (ARN) used for SSL connection to the endpoint.
database_nametextThe name of the database at the endpoint.
dms_transfer_settingsjsonbThe settings for the DMS Transfer type source.
doc_db_settingsjsonbProvides information that defines a DocumentDB endpoint.
dynamo_db_settingsjsonbThe settings for the DynamoDB target endpoint.
elasticsearch_settingsjsonbThe settings for the OpenSearch source endpoint.
endpoint_identifiertext=The database endpoint identifier.
endpoint_typetext=The type of endpoint. Valid values are source and target.
engine_display_nametextThe expanded name for the engine name. For example, if the EngineName parameter is 'aurora', this value would be 'Amazon Aurora MySQL'.
engine_nametext=The database engine name. Valid values, depending on the EndpointType, include 'mysql', 'oracle', 'postgres', 'mariadb', 'aurora', 'aurora-postgresql', 'redshift', 's3', 'db2', 'db2-zos', 'azuredb', 'sybase', 'dynamodb', 'mongodb', 'kinesis', 'kafka', 'elasticsearch', 'documentdb', 'sqlserver', 'neptune', and 'babelfish'.
external_idtextValue returned by a call to CreateEndpoint that can be used for cross-account validation.
external_table_definitiontextThe external table definition.
extra_connection_attributestextAdditional connection attributes used to connect to the endpoint.
gcp_my_sql_settingsjsonbSettings in JSON format for the source GCP MySQL endpoint.
ibm_db2_settingsjsonbThe settings for the IBM Db2 LUW source endpoint.
kafka_settingsjsonbThe settings for the Apache Kafka target endpoint.
kinesis_settingsjsonbThe settings for the Amazon Kinesis target endpoint.
kms_key_idtextAn KMS key identifier that is used to encrypt the connection parameters for the endpoint.
microsoft_sql_server_settingsjsonbThe settings for the Microsoft SQL Server source and target endpoint.
mongo_db_settingsjsonbThe settings for the MongoDB source endpoint.
my_sql_settingsjsonbThe settings for the MySQL source and target endpoint.
neptune_settingsjsonbThe settings for the Amazon Neptune target endpoint.
oracle_settingsjsonbThe settings for the Oracle source and target endpoint.
partitiontextThe AWS partition in which the resource is located (aws, aws-cn, or aws-us-gov).
portbigintThe port value used to access the endpoint.
postgre_sql_settingsjsonbThe settings for the PostgreSQL source and target endpoint.
redis_settingsjsonbThe settings for the Redis target endpoint.
redshift_settingsjsonbSettings for the Amazon Redshift endpoint.
regiontextThe AWS Region in which the resource is located.
s3_settingsjsonbThe settings for the S3 target endpoint.
server_nametextThe name of the server at the endpoint.
service_access_role_arntextThe Amazon Resource Name (ARN) used by the service to access the IAM role.
sp_connection_nametext=, !=, ~~, ~~*, !~~, !~~*Steampipe connection name.
sp_ctxjsonbSteampipe context in JSON form.
ssl_modetextThe SSL mode used to connect to the endpoint. The default value is none.
statustextThe status of the endpoint.
sybase_settingsjsonbThe settings for the SAP ASE source and target endpoint.
tagsjsonbA map of tags for the resource.
tags_srcjsonbA list of tags currently associated with the replication instance.
timestream_settingsjsonbThe settings for the Amazon Timestream target endpoint. For more information, see the TimestreamSettings structure.
titletextTitle of the resource.
usernametextThe user name used to connect to the endpoint.

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_endpoint