RDS - Relational databases
Table of Contents
- Plans
- Choosing a database plan
- Create an instance
- Update an instance
- Backup and Recovery
- Tunneling to your database
- Exporting your database
- Restoring to a database
- Database import errors
- Cloning a service instance using cg-manage-rds
- Opening a shell to your cloud.gov database
- Encryption
- Working with OracleDB
- Version information
- The broker in GitHub
If your application uses relational databases for storage, you can use the AWS RDS service to create a database instance. The redundant
label in an RDS plan name indicates it is a Multi-AZ (Availability Zone) deployment.
Plans
Plan Name | Description | Software Version (default) |
---|---|---|
micro-psql |
Single-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 1 GiB memory | 15.x* |
micro-psql-redundant |
Multi-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 1 GiB memory | 15.x* |
small-psql |
Single-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 2 GiB memor | 15.x* |
small-psql-redundant |
Multi-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 2 GiB memory | 15.x* |
medium-psql |
Single-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 4 GiB memory | 15.x* |
medium-psql-redundant |
Multi-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 4 GiB memory | 15.x* |
medium-gp-psql |
Single-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 8 GiB memory | 15.x* |
medium-gp-psql-redundant |
Multi-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 8 GiB memory | 15.x* |
large-gp-psql |
Single-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 8 GiB memory | 15.x* |
large-gp-psql-redundant |
Multi-AZ RDS instance of PostgreSQL, minimum 1 core, minimum 8 GiB memory | 15.x* |
xlarge-gp-psql |
Single-AZ RDS instance of PostgreSQL, minimum 2 cores, minimum 16 GiB memory | 15.x* |
xlarge-gp-psql-redundant |
Multi-AZ RDS instance of PostgreSQL, minimum 2 cores, minimum 16 GiB memory | 15.x* |
small-mysql |
Single-AZ RDS instance of MySQL, minimum 1 core, minimum 2 GiB memory | 8.x.x* |
small-mysql-redundant |
Multi-AZ RDS instance of MySQL, minimum 1 core, minimum 2 GiB memory | 8.x.x* |
medium-mysql |
Single-AZ RDS instance of MySQL, minimum 2 cores, minimum 4 GiB memory | 8.x.x* |
medium-mysql-redundant |
Multi-AZ RDS instance of MySQL, minimum 2 cores, minimum 4 GiB memory | 8.x.x* |
medium-gp-mysql |
Single-AZ RDS instance of MySQL, minimum 1 core, minimum 8 GiB memory | 8.x.x* |
medium-gp-mysql-redundant |
Multi-AZ RDS instance of MySQL, minimum 1 core, minimum 8 GiB memory | 8.x.x* |
large-gp-mysql |
Single-AZ RDS instance of MySQL, minimum 1 core, minimum 8 GiB memory | 8.x.x* |
large-gp-mysql-redundant |
Multi-AZ RDS instance of MySQL, minimum 1 core, minimum 8 GiB memory | 8.x.x* |
xlarge-gp-mysql |
Single-AZ RDS instance of MySQL, minimum 2 cores, minimum 16 GiB memory | 8.x.x* |
xlarge-gp-mysql-redundant |
Multi-AZ RDS instance of MySQL, minimum 2 cores, minimum 16 GiB memory | 8.x.x* |
medium-oracle-se2 |
Single-AZ RDS instance of Oracle SE2, minimum 1 core, minimum 4 GiB memory | AWS RDS Latest Default |
*Note: The actual database engine version used is the latest minor/patch version offered by AWS RDS for this major version
Only the micro-psql
and small-mysql
plans are available in sandbox spaces.
You can always view an up-to-date version of this list directly in your command line as well with the following command (using cf
CLI version 6):
cf marketplace -s aws-rds
Or, the following command (using cf
CLI version 7 or later):
cf marketplace -e aws-rds
The dedicated plans listed above (marked “AWS RDS Latest”) deploy the default version as advertised by AWS. If you need to determine the exact version of the RDS service deployed, see this knowledge base article.
Additional Cost: All databases have a limit of 1TB in storage. After 1TB, each additional terabyte will cost $300 per month.
Choosing a database plan
For PostgreSQL and MySQL, we offer a range of database plans in different sizes (e.g. micro-psql
, small-psql
,
etc).
The primary differences between each database plan size are the available CPU cores and memory for databases created with that plan. These parameters may be important to consider when choosing a plan for an application that is heavily CPU-bound or memory-bound.
The maximum number of available database connections will also differ between each plan size, in proportion to the available memory of that plan. Unfortunately, specifying the exact maximum number of database connections for each plan size is difficult because the maximum is calculated by AWS using a formula and not all of the inputs to the formula are known in advance to customers.
In general, the following guidance can be offered for the database plan sizes:
micro-*
plans: Good for prototyping and developmentsmall-*
plans: Good for low-traffic applicationsmedium-*
plans: Good general purpose plan for applicationslarge-*
plans: Good for high-traffic applicationsxlarge-*
plans: Good for very high-traffic applications
Once you have chosen a plan size, you should consider whether you need to run your database in multiple availability zones, which increases the availability and durability of your database.
For databases used for development or staging environments, redundancy may not be as critical. But for databases used in production applications, you should always use a *-redundant
database plan.
Create an instance
To create a service instance run the following command:
cf create-service aws-rds ${SERVICE_PLAN_NAME} ${SERVICE_NAME}
For example, if you wanted to create a new micro PostgreSQL instance called my-service-db
, run the following command:
cf create-service aws-rds micro-psql my-service-db
Setting optional parameters
There are several optional parameters that you can specify when creating a new instance:
Name | Description | Default Value |
---|---|---|
storage |
Number of GB available to the database instance | 10 |
enable_functions |
Boolean to enable functions, procedures, and triggers on MySQL databases | false |
version |
Specifies a supported major version in RDS (must be in quotes) | PostgreSQL: 15 , MySQL 8.0 |
backup_retention_period |
Specifies a number of days to retain daily snapshots. | 14 |
binary_log_format |
Specifies the format for MySQL binary logging. Only supported for MySQL database plans. Valid options: ROW , STATEMENT , MIXED . |
— |
enable_pg_cron |
Boolean to enable pg_cron extension on PostgreSQL databases (requires PostgreSQL 12.5 and above; see example below for details) |
false |
A couple of notes regarding the optional version
parameter:
- It is currently only supported for dedicated MySQL and PostgreSQL instances; if you specify it for any other type of instance it is ignored.
- It only supports major version numbers (e.g. “8.0”); if you specify a minor/patch level version (e.g., “12.16” for PostgreSQL or “8.0.32” for MySQL), the command will fail.
- The version number must be provided in double quotes (
"
); this is because the value is treated as a string to account for different engine types and version schemes.
These are the current supported major versions for PostgreSQL:
- 12
- 13
- 14
- 15
*Note: For PostgreSQL versions 15+ , using SSL is required when connecting to your database. As such, you will need to configure your client library to use SSL when connecting to your database.
These are the current supported major versions for MySQL:
- 8.0
The backup_retention_period
can be no less than 14 days but extended up to 35 days.
Examples of optional parameters
If you want to specify the storage available (in gigabytes) to the instance:
cf create-service aws-rds \
${SERVICE_PLAN_NAME} \
${SERVICE_NAME} \
-c '{"storage": 50}'
To enable functions, triggers, and procedures in MySQL instances:
cf create-service aws-rds \
${MYSQL_SERVICE_PLAN_NAME} \
${SERVICE_NAME} \
-c '{"enable_functions": true}'
To specify the binary log format for a MySQL instance:
cf create-service aws-rds \
${MYSQL_SERVICE_PLAN_NAME} \
${SERVICE_NAME} \
-c '{"binary_log_format": "ROW"}'
To enable the pg_cron
extension for a PostgreSQL instance:
cf create-service aws-rds \
${POSTGRESQL_SERVICE_PLAN_NAME} \
${SERVICE_NAME} \
-c '{"enable_pg_cron": true}'
After running this command, you must finish setting up pg_cron on your instance. You can use cf-service-connect to connect to your instance, or connect via an application. Note that you must target the postgres
database. To do this via cf-service-connect
, run \c postgres
in the psql shell.
To specify a major version of a new instance, e.g., PostgreSQL version 14 (please note the double quotes ("
) around the version number; they are required):
cf create-service aws-rds \
micro-psql \
my-test-service \
-c '{"version": "14"}'
To extend the backup retention period for a database to 30 days:
cf create-service aws-rds \
micro-psql \
my-test-service \
-c '{"backup_retention_period": 30}'
You can combine multiple optional parameters as long as the JSON is well-formed:
cf create-service aws-rds \
small-mysql \
my-test-service \
-c '{"version": "8.0", "storage": 35}'
Instance creation time
Dedicated RDS instance provisioning can take anywhere between 5 minutes and 60
minutes. During instance provisioning, the results of cf services
or cf service SERVICE_NAME
will show status as create in progress
, as in the following example:
> cf services
name service plan bound apps last operation
test-oracle aws-rds medium-oracle-se2 create in progress
Once the instance is ready for use, it will show create succeeded
as below:
> cf services
name service plan bound apps last operation
test-oracle aws-rds medium-oracle-se2 create succeeded
By default, when new spaces are created in your organization, an application security group (ASG) is applied that doesn’t allow any outgoing traffic. You will need to update egress traffic rules to allow for your app to reach the database.
Update an instance
To update an existing service instance to a different plan run the following command:
cf update-service ${SERVICE_NAME} -p ${NEW_SERVICE_PLAN_NAME}
${NEW_SERVICE_PLAN_NAME}
can be any of the dedicated service plans that are listed above.
There are a couple of caveats regarding this command with the -p
flag:
- You can only update using plans with the same database engine as your existing service instance. This means that if your original service instance was using a PostgreSQL plan (e.g.,
micro-psql
), you can only update to one of the otherpsql
-based plans. - You can only switch service plans with this command; you cannot do things like upgrade your database version.
You can update to larger or smaller plans depending on your specific needs, and you can switch between redundant and non-redundant plans.
NOTE: All updates are applied immediately. Performing an update in place like this will result in a brief period of downtime (seconds to minutes) while the service instance restarts as a part of the update.
Setting optional parameters
There are several optional parameters that you can specify when updating an existing instance:
Name | Description | Reboot required? |
---|---|---|
storage |
Number of GB available to the database instance | No |
backup_retention_period |
Specifies a number of days to retain daily snapshots. | No |
binary_log_format |
Specifies the format for MySQL binary logging. Only supported for MySQL database plans. Valid options: ROW , STATEMENT , MIXED . |
Yes |
enable_pg_cron |
Boolean to enable pg_cron extension on PostgreSQL databases (requires PostgreSQL 12.5 and above) |
Yes |
enable_functions |
Boolean to enable functions, procedures, and triggers on MySQL databases | Yes |
storage_type |
RDS storage type to use for the database. Valid options: gp3 |
No |
Examples of optional parameters
If you want to increase the storage available to the instance to be 50 GB:
cf update-service ${SERVICE_NAME} -c '{"storage": 50}'
Note that you can only update to a larger size. If you want to downgrade to a lesser size, please email support@cloud.gov for assistance.
To enable functions, triggers, and procedures for a MySQL instance:
cf update-service ${SERVICE_NAME} \
-c '{"enable_functions": true}'
To update the binary log format for a MySQL instance:
cf update-service ${SERVICE_NAME} \
-c '{"binary_log_format": "ROW"}'
To enable the pg_cron
extension for a PostgreSQL instance:
cf update-service ${SERVICE_NAME} \
-c '{"enable_pg_cron": true}'
To disable the pg_cron
extension for a PostgreSQL instance:
cf update-service ${SERVICE_NAME} \
-c '{"enable_pg_cron": false}'
To update the database to use gp3
storage:
cf update-service ${SERVICE_NAME} \
-c '{"storage_type": "gp3"}'
Please note that databases must be at least 20 GB in size to use gp3
as the storage type. If you get an error during the update about your database storage size, try specifying a minimum value of 20
for storage
(you can also choose a larger value) in the update-service
command:
cf update-service ${SERVICE_NAME} \
-c '{"storage_type": "gp3", "storage": 20}'
For the parameters identified as requiring a reboot, you need to request an instance reboot after the update in order for the changes to be applied. You can request a reboot of your RDS instance by emailing support@cloud.gov.
A note about upgrading major versions
You cannot update an existing instance to a new major version with the update-service
command. If you’d like to update your existing database instance to a new major version, please email support@cloud.gov for assistance.
Rotate your credentials
NOTE: Rotating your database credentials will likely incur some downtime for your application. While AWS documentation states that existing connections using your current password are not dropped, depending on how your application handles database connections you could see errors trying to establish new connections until the application is restaged with the new credentials.
To change the password of your database instance:
cf update-service ${SERVICE_NAME} \
-c '{"rotate_credentials": true}'
Once that command has finished running, you need to unbind your database instance from your application and re-bind it so that the application receives the updated credentials. Please note that you may want to wait about a minute between running cf unbind-service
and cf bind-service
otherwise you may get an error indicating that the database is not ready.
cf unbind-service <application-name> ${SERVICE_NAME} # wait a minute or so after running this
cf bind-service <application-name> ${SERVICE_NAME}
You will also need to delete and recreate any service keys for your database instance to incorporate the new credentials into the keys:
cf delete-service-key ${SERVICE_NAME} <service-key-name>
cf create-service-key ${SERVICE_NAME} <service-key-name>
Lastly, you need to restage your application so that it uses the updated credentials (tip: you can use the --strategy rolling
flag to ensure your application instances remain available to handle traffic):
cf restage <application-name> --strategy rolling
Bind to an application
To use the service instance from your application, bind the service instance to the application. For an overview of this process and how to retrieve the credentials for the service instance from environment variables, see Bind a Service Instance and the linked details at Delivering Service Credentials to an Application.
In short, cf bind-service
will provide a DATABASE_URL
environment variable for your app, which is then picked up by the restage
.
The contents of the DATABASE_URL
environment variable contain the credentials to access your database. Treat the contents of this and all other environment variables as sensitive.
Please note: If you are binding a service instance to a new space, please review and adjust your space egress setting. By default, all newly made spaces have their space egress set to closed which means any requests to the open internet or our brokered services will be blocked. For an overview of space egress settings, see Space Egress.
Backup and Recovery
Cloud.gov has provisioned AWS RDS databases so customers can restore to any point-in-time within their backup retention period (14 days minimum, up to 35 days). The point-in-time recovery may result in up to 5 minutes of data loss.
RDS automatically retains daily backups for 14 days. These backups are AWS RDS storage volume snapshots, backing up the entire DB instance
and not just individual databases. You can extend the length of retention up to 35 days by using the backup_retention_period
option detailed above. In addition, transaction logs from the AWS RDS instance are written to S3 every 5 minutes to enable point-in-time recovery.
If you need to have a database restored using one of these backups, email support@cloud.gov with:
- the Cloud.gov organization name
- the space name
- the database to restore
- the name of the application(s) connected to the impacted database service
- the point-in-time to restore (e.g. 15:15 EST on 12/12/2022).
- phone numbers and contact information if it’s an urgent situation
- for non-emergency situations, please provide at least 48 hours advance notice.
Please do not share any passwords or details of any exploit or compromise. We’ll call you if necessary, and we’ll never ask you for a password over the phone.
The Cloud.gov support team will restore to the nearest point in time BEFORE the time you’ve specified.
We’ll confirm your information and remind you that a restoration may result in a brief period of downtime with database connectivity. Once we receive confirmation from you to proceed, we’ll perform the restore, which results in a new DB instance being created in AWS RDS. Cloud.gov support will take care of renaming the new instance and configuring it with the same VPC and security group as the old instance in AWS so that it can still be found by your bound application(s) once the restoration is complete.
When the restore process is completely finished, we’ll notify you and ask you to confirm that your application(s) is still functioning properly and that the data is properly restored. We’ll also coordinate with you to determine when it would be appropriate to remove the old instance, particularly if it is needed for something such as a security audit or forensic analysis.
When we remove the old database instance, we will not retain snapshots or backups of it unless we’re explicitly asked to do so. We’ll remind you of this when coordinating a specific date and time to remove the old instance.
If you deleted your database instance and want to recover it, the recovery must be done within 14 days of the instance being deleted. We can perform a restoration using the automated backups that are retained for that 14 day window after a database is removed.
You can also create manual backups using the export process described below. In general, you are responsible for making sure that your backup procedures are adequate for your needs; see CP-9 in the Cloud.gov SSP.
Tunneling to your database
Databases on cloud.gov can only be connected to from other resources within our internal network. You cannot make a connection directly from your local machine to a database hosted on cloud.gov.
To connect to databases hosted on cloud.gov, you need to use an SSH tunnel. Two options for creating an SSH tunnel are outlined below.
Using cf connect-to-service
to open a tunnel
First, open a terminal and connect to an instance using the cf-service-connect plugin to create a SSH tunnel:
$ cf connect-to-service -no-client ${APP_NAME} ${SERVICE_NAME}
...
Host: localhost
Port: ...
Username: ...
Password: ...
Name: ...
If this fails to open a SSH tunnel, try deleting any existing connect-to-service
service keys first:
cf delete-service-key ${SERVICE_NAME} SERVICE_CONNECT
Then try the previous step again.
Once the SSH tunnel is created, keep it running in that terminal window to use the tunnel to make database connections.
The Port
specified in the terminal output is the port on your local machine where the tunnel to your database is open. You should use this port when making connections to the database on localhost
for utilities like pg_dump
, mysqldump
, or mysqlsh
.
Using cf ssh
Note: you can find all the information for accessing your database (username, password, host, database name) by running
cf env app_name
for your app and looking at thecredentials
for your RDS database
Open an SSH tunnel to your database:
cf ssh -N -L <tunnel-port>:<host>:<db-port> <application_name>
with these values:
<tunnel-port>
- port to open on your local machine for accessing your database. This value can be any port that is available for use on your local machine.<db-port>
- port database is running on in RDS<host>
- AWS host for accessing your database<application_name>
- your application name
If the cf ssh
command succeeded, you should see an empty shell prompt that looks something like, which indicates that the SSH tunnel is open:
vcap@abc123-de45-fg67-hi89-jk10:~$
Once the SSH tunnel is open, your database should be available for connections on localhost:<port>
.
Exporting your database
Exporting using cg-manage-rds
To perform a basic export of a PostgreSQL instance using the compressed format using cg-manage-rds
:
cg-manage-rds export -o "-F c" -f ./backup.pg ${SERVICE_NAME}
This will create an export using pg_dump
named backup.pg
. Other options for the pg_dump command can be pased as a string with the -o
option.
Exporting a database manually
- Create an SSH tunnel to your database and keep it running in that terminal window
- Open a separate terminal session in another window/tab
- View the credentials for accessing your database by running
cf env app_name
for the app connected to your database and looking at thecredentials
for your RDS database -
In the separate terminal window/tab, create the backup file (be sure to tailor the backup/export command to your specific needs).
For example, to create a dump of a PostgreSQL database:
$ pg_dump -F c \ --no-acl \ --no-owner \ -f backup.pg \ postgresql://<username>:${PASSWORD}@localhost:<port>/<db_name>
with the values:
<username>
- username for accessing your database<port>
- port opened for SSH tunnel to your database<db_name>
- database name
This command will create the
backup.pg
file on your local machine in the current working directory. - When you are finished, you can terminate the SSH tunnel.
Restoring to a database
Restoring to a database using cg-manage-rds
This is a simple example of importing a previous export to database service instance.
By default cg-manage-rds
adds options to remove ownership and create new objects to make porting easy.
cg-manage-rds import -o "-F c" -f ./backup.pg ${SERVICE_NAME}
Restoring to a database manually
Once you have a database backup file, you can import the dump into another database.
- If you want to restore to a cloud.gov hosted database, you will need to first open a tunnel to that database which will expose a port on your local machine for connecting to the database.
- If you are restoring to a local database, opening a tunnel is not necessary.
- View the credentials necessary for accessing your database by running
cf env <app_name>
on the app connected to your database. -
Use the commands for PostgreSQL/MySQL below to restore your database.
- For importing to a cloud.gov database, the
<port>
value should be the port opened by the SSH tunnel on your local machine. - For importing to a local database, the
<port>
value should be whatever is configured for that database service
- For importing to a cloud.gov database, the
PostgreSQL
This pg_restore invocation does not drop all of the objects in the database when loading the dump, so if objects exist in a local copy of the database already, you might run into inconsistencies when doing a pg_restore
:
pg_restore --clean --no-owner --no-acl \
-h localhost \
-p <port> \
-U <username>
--dbname=<database-name> backup.pg
If you want to drop and recreate the database before doing a restore, thus avoiding any data collisions, use the --create
flag:
pg_restore --create --clean --no-owner --no-acl \
-h localhost \
-p <port> \
-U <username>
--dbname=<database-name> backup.pg
MySQL
Run this command to import a database backup into a MySQL database using the mysqlsh
tool:
mysqlsh -u username -p -h host -P port -D db_name -f path-to-file.sql
with these values:
username
- username for accessing your databasehost
- AWS host for accessing your databaseport
- port for accessing your databasedb_name
- database name for accessing your databasepath-to-file.sql
- Full path to the database backup file on your machine
Database import errors
MySQL
If you get an error like ERROR: 1227
when trying to import to your database:
-
Make sure that
enable_functions
is enabled for your database:# on Linux / Mac cf update-service ${SERVICE_NAME} \ -c '{"enable_functions": true}' # on Windows cf update-service ${SERVICE_NAME} \ -c "{\"enable_functions\": true}"
After making these changes, make sure to request a database reboot by contacting cloud.gov support.
-
Make sure that your database dump was generated with the
--set-gtid-purged=OFF
option. For example:mysqldump -h <host> \ -u <username> \ -p \ --set-gtid-purged=OFF \ <database_name> > backup.sql
If those steps do not help, additional remediation steps can be found in the AWS knowledge center article on how to resolve this error.
Cloning a service instance using cg-manage-rds
This is a simple example of replicating database service instance to another instance using cg-manage-rds
. The destination database must be created beforehand. The export is downloaded locally as in the export
command.
cg-manage-rds clone ${SERVICE_NAME_SOURCE} ${SERVICE_NAME_DEST}
Opening a shell to your cloud.gov database
Using cf connect-to-service
to start a database shell
Run this command:
cf connect-to-service <APP_NAME> <SERVICE_NAME>
with the values:
<APP_NAME>
- the name of the app connected to your database<SERVICE_NAME>
- the name of your database services
By default, cf connect-to-service
should open a database shell for the relevant database type if you have the utility installed on your machine (e.g. psql
for PostgreSQL databases).
Using cf ssh
to start a database shell
- Create a tunnel to your database
-
In another terminal window, connect to the database:
myapp_guid=$(cf app --guid <app_name>) creds=$(cf curl /v2/apps/$myapp_guid/env \ | jq -r '[.system_env_json.VCAP_SERVICES."aws-rds"[0].credentials \ | .username, .password] \ | join(":")') dbname=$(cf curl /v2/apps/$myapp_guid/env \ | jq -r '.system_env_json.VCAP_SERVICES."aws-rds"[0].credentials \ | .name') psql postgres://$creds@localhost:5432/$dbname
with values:
<app_name>
- The name of the app connected to your database
Encryption
Every RDS instance configured through cloud.gov is encrypted at rest. We use the industry standard AES-256 encryption algorithm to encrypt your data on the server that hosts your RDS instance. The RDS then handles authenticating access and decrypting your data, with minimal performance impact and without requiring you to modify your applications.
Working with OracleDB
Since Oracle is not open-source there are fewer resources available online to get started working with OracleDB and Cloud Foundry. We provide a few tips here. This example worked with ojdbc8.jar
, and will likely needs some tweaks for ojdbc10.jar
.
Demo with Spring Music and Oracle
To demonstrate the core Cloud Foundry / OracleDB functionality, we’ll start by deploying the Spring Music app.
First, though, one needs the proprietary Oracle database drivers.
Visit the Oracle drivers’ site at http://www.oracle.com/technetwork/database/application-development/jdbc/downloads/index.html and download the ojdbc8.jar
from the latest available release. You will need to have a valid Oracle profile account for the download.
Then, clone the repository and make a libs/
directory:
git clone https://github.com/cloudfoundry-samples/spring-music
cd spring-music
mkdir libs/
Copy the downloaded ojdbc8.jar
to the libs/
directory of spring-music
.
Edit build.gradle
, look for the following near line 60:
// Oracle - uncomment one of the following after placing driver in ./libs
// compile files('libs/ojdbc8.jar')
// compile files('libs/ojdbc7.jar')
and remove the //
comment from the line for libs/ojdbc8.jar
. Save the build.gradle
file.
After installing the ‘cf’ command-line interface for Cloud Foundry, and logging in to cloud.gov, cf login --sso -a https://api.fr.cloud.gov
, the application can be built and pushed using these commands:
cf create-service aws-rds medium-oracle-se2 spring-oracle
# Wait 20 minutes: get coffee, make a sandwich, ...
./gradlew clean assemble
cf push --no-start
cf bind-service spring-music spring-oracle
cf restart spring-music
When the restart completes, you can visit the app and view in the upper-right-hand i
button that it’s now using an OracleDB, or view the /appinfo
path, as in: curl https://spring-music-ADJECTIVE-ANIMAL.app.cloud.gov/appinfo
Connecting to Oracle
Install Oracle’s instantclient-basiclite
and instantclient-sqlplus
for your operating system.
To get the database connection information, we’ll use
Cloud Foundry service keys as follows, for the
case of an Oracle database called spring-oracle
:
$ cf create-service-key spring-oracle-key
Creating service key spring-oracle-key for service instance spring-oracle ...
OK
$ cf service-key spring-oracle spring-oracle-key
Getting key spring-oracle-key for service instance spring-oracle ...
{
"name": "ORCL",
"host": "cg-aws-broker-prod.RANDOMSTRING.us-gov-west-1.rds.amazonaws.com",
"password": "secretpassword",
"port": "1521",
"uri": "oracle://random-username:secretpassword@cg-aws-broker-prodRANDOMSTRING.us-gov-west-1.rds.amazonaws.com:1521/ORCL",
"username": "random-username"
}
Make an SSH tunnel from your workstation to Cloud Foundry to the OracleDB using the host:
value, e.g. using port 15210
on the localhost:
cf ssh -N -L 15210:cg-aws-broker-prod.RANDOMSTRING.us-gov-west-1.rds.amazonaws.com:1521 spring-music
Now connect using sqlplus random-username/secretpassword@host:port/ORCL
, where host is localhost
and port
is the first part of the -L
connection string above. e.g.:
./sqlplus random-username/secretpassword@localhost:15210/ORCL
Then you can use SQLPLUS commands like SELECT table_name FROM user_tables;
Version information
The software versions listed in the table above are for new instances of those plans.
New instances of dedicated RDS plans use the latest default database version available from AWS RDS GovCloud (US) at the time.
The PostgreSQL and MySQL plans are configured to automatically upgrade currently-running dedicated instances to the most recent compatible minor version available via AWS RDS GovCloud (US).
For Oracle plans, minor upgrades are not automatic. To upgrade an existing Oracle database instance, please contact support@cloud.gov and schedule a maintenance window for the upgrade to take place.
The broker in GitHub
You can find the broker here: https://github.com/cloud-gov/aws-broker.