Simple Ansible Playbook to Create RDS Instance
Create an Oracle RDS database in AWS within minutes by automating the entire provisioning process using Ansible. For this demo I’m running Ansible (2.9.2) and the latest version of AWS CLI on RHEL8.
Pre-reqs
- Install the latest version of the AWS CLI
1 2 3
curl "https://s3.amazonaws.com/aws-cli/awscli-bundle.zip" -o "awscli-bundle.zip" unzip awscli-bundle.zip sudo ./awscli-bundle/install -i /usr/local/aws -b /usr/local/bin/aws
- Configure credentials by adding keys to the credentials file
~/.aws/credentials
1 2 3
[default] aws_access_key_id=<put access key here> aws_secret_access_key=<put secret access key here>
Note: boto is required for the Ansible modules. Ansible uses python libraries in the backend, so you need to install the boto on your system. Use the below command to download the boto module.
1
pip3 install boto
Create Ansible Playbook
Create an empty file called create-rds-oracle.yml
, then copy the content below into the playbook. Modify the playbook to fit your specs.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
- name: create-oracle-rds
hosts: localhost
connection: local
gather_facts : false
tasks:
- name: provision oracle rds intance
rds:
command: create
region: us-east-1
instance_name: orards
db_engine: oracle-se2
size: "10"
instance_type: db.m5.large
license_model: bring-your-own-license
username: master
password: "your-password"
tags:
environment: test
Run Ansible Playbook
Create the Oracle RDS instance by running the playbook. Use the command below.
1
ansible-playbook create-rds-oracle.yml
A new RDS instance should be created. It should look something like this in AWS Console. Auto-magically spun-up RDS instance
This post is licensed under CC BY 4.0 by the author.