The following shows you how to connect to Relational Database Service (RDS) database instances in private Virtual Private Cloud (VPC) subnets from a local machine using EC2 bastion hosts and AWS Systems Manager (SSM) instead of using SSH directly. It assumes,
- You have an EC2 instance running.
- You have security groups configured so the EC2 instance has access to the RDS database.
If either of those isn't the case, follow those two steps in this article and then head back here.
If you let AWS store your database secrets in Secrets Manager when creating the database, all connection information is in the secret.
From the AWS Console
From the Secrets Manager Console, select to database secret.
Select Retrieve secret value, you'll need host, dbname, username, and password in the following steps.
From the EC2 Console, connect to the EC2 instance with access to your database using Session Manager.
From the launched terminal, run the following. This is specific to PostgreSQL, but you run equivalent commands for your database.# Install postgresqlsudo amazon-linux-extras install -y postgresql14# Connect using the values copied in step 2# After entering it, you'll be prompted for the passwordpsql -h [YOUR_HOST] -d [YOUR_DB_NAME] -U [YOUR_USERNAME] -W-- List tables\dt-- Run your favorite queriesSELECT * FROM [YOUR_TABLE];
You're connected! But we can do better.
From the command line
Run the following to see if you have
session-manager-plugininstalled. If you don't, run the commands here to install it.session-manager-plugin --version
To start the SSM session, you need the EC2 instance ID. You can either get it from the AWS Console, or run the following with appropriate filters if you have lots of instances. The following assumes you have jq installed and have instance tags.aws ec2 describe-instances \--profile [YOUR_PROFILE] \--filter Name=tag:[YOUR_TAG_KEY],Values=[YOUR_TAG_VALUE] \| jq -r '.Reservations.Instances.InstanceId'
Given the EC2 instance ID, run the following to start the session,aws ssm start-session \--profile [YOUR_PROFILE] \--target [YOUR_INSTANCE_ID]
You're connected from your own terminal! Now, run the commands in step 4 above to connect to your database and start executing queries.