AWS Aurora PostgreSQL
Amazon Aurora is a fully managed relational database engine that's compatible with PostgreSQL. Aurora includes a high-performance storage subsystem. Its PostgreSQL-compatible database engines are customized to take advantage of that fast distributed storage. The underlying storage grows automatically as needed. An Aurora cluster volume can grow to a maximum size of 128 tebibytes (TiB). Aurora also automates and standardizes database clustering and replication, which are typically among the most challenging aspects of database configuration and administration.
Made by
Massdriver
Official
Yes
Clouds
Tags
AWS Aurora PostgreSQL
Amazon Aurora (Aurora) is a fully managed relational database engine that's compatible with PostgreSQL. You already know how PostgreSQL combines the speed and reliability of high-end commercial databases with the simplicity and cost-effectiveness of open-source databases. The code, tools, and applications you use today with your existing PostgreSQL databases can be used with Aurora. With some workloads, Aurora can deliver up to three times the throughput of PostgreSQL without requiring changes to most of your existing applications.
Aurora includes a high-performance storage subsystem. Its PostgreSQL-compatible database engines are customized to take advantage of that fast distributed storage. The underlying storage grows automatically as needed. An Aurora cluster volume can grow to a maximum size of 128 tebibytes (TiB). Aurora also automates and standardizes database clustering and replication, which are typically among the most challenging aspects of database configuration and administration.
Aurora is part of the managed database service Amazon Relational Database Service (Amazon RDS). Amazon RDS is a web service that makes it easier to set up, operate, and scale a relational database in the cloud.
Design Decisions
- Aurora Clusters can only be provisioned on internal or private subnets.
- A KMS key is created for encryption and retained after cluster deletion.
- Tags are copied to snapshots.
- Daily snapshots are configured.
- Root username and password are automatically generated to reduce exposure.
- Username is generated when not being restored from snapshot, otherwise it will use the snapshots username note
- Password is reset on snapshot restore
- No schema is created by default.
- No blue/green support as it is not supported for PostgreSQL yes.
- Instances AZs are auto-assigned by AWS
- 2 artifacts, one for the writer, one for the readers. If no readers the writer will be present here so you can
- For applications that dont use load balanced reader, the writer endpoint can be read from
- Minimum retention period for backups is 1 day, as they cannot be disabled in Aurora
Runbook
Connection Issues
If unable to connect to the Aurora PostgreSQL cluster:
Check the cluster's current status and endpoint information:
aws rds describe-db-clusters --query "DBClusters[?DBClusterIdentifier=='<cluster_identifier>'].[Status, Endpoint, ReaderEndpoint]" --output table
Expect to see the status of the cluster along with the primary and reader endpoints.
Verify the security group rules to ensure proper ingress rules are set up:
aws ec2 describe-security-groups --group-ids <security_group_id> --query "SecurityGroups[*].[GroupId, IpPermissions]" --output table
Confirm that the ingress rules allow traffic from your IP or subnet.
High Latency Queries
If queries are running slow, use the following commands to identify problematic queries:
Connect to your PostgreSQL instance and check for slow queries:
SELECT query, state, waiting, query_start
FROM pg_stat_activity
WHERE state <> 'idle'
ORDER BY query_start DESC;
Look for queries that have been running for a long time and investigate their execution plans.
Enable and review PostgreSQL's slow query log:
ALTER SYSTEM SET log_min_duration_statement = 1000; -- Logs queries that take longer than 1000ms
SELECT pg_reload_conf();
This will log slow queries to help identify and optimize them.
Backup Verification
Ensure your backups are being created and managed as expected.
List the available snapshots for your Aurora PostgreSQL cluster:
aws rds describe-db-cluster-snapshots --db-cluster-identifier <cluster_identifier> --query "DBClusterSnapshots[].[DBClusterSnapshotIdentifier, SnapshotCreateTime]" --output table
Verify that snapshots are created according to your backup policy.
Check backup retention settings:
aws rds describe-db-clusters --db-cluster-identifier <cluster_identifier> --query "DBClusters[0].[BackupRetentionPeriod]" --output table
Ensure that the retention period is set according to your organization's policy.
Disk Space Usage
Monitor and manage the disk space usage for your Aurora PostgreSQL cluster.
Check the current disk space usage metrics:
aws cloudwatch get-metric-statistics --namespace "AWS/RDS" --metric-name "FreeStorageSpace" --dimensions Name=DBClusterIdentifier,Value=<cluster_identifier> --statistics Average --period 300 --start-time $(date -u -d '1 hour ago' +"%Y-%m-%dT%H:%M:%SZ") --end-time $(date -u +"%Y-%m-%dT%H:%M:%SZ")
Monitor the free storage space to ensure you do not run out of disk space.
Reclaiming disk space in PostgreSQL:
VACUUM;
VACUUM FULL; -- This might lock tables, use it during maintenance windows
REINDEX DATABASE your_database_name;
Regular maintenance tasks like vacuum and reindex help to reclaim space and improve performance.
Links
Variable | Type | Description |
---|---|---|
availability.autoscaling_mode | string | No description |
availability.min_replicas | integer | Replicas and primary are automatically spread across AWS zones. |
backup.retention_period | integer | The days to retain backups for. |
backup.skip_final_snapshot | boolean | Determines whether a final DB snapshot is created before the DB cluster is deleted. If true is specified, no DB snapshot is created. |
database.ca_cert_identifier | string | The identifier of the CA certificate for the DB instances. Learn more. |
database.deletion_protection | boolean | Explicitly requires this field to be unset before allowing deletion. |
database.source_snapshot | string | Cluster or database snapshot ARN. Specifies whether or not to create this cluster from a snapshot. Aurora clusters can be restored from cluster snapshots or database snapshots. Learn more |
database.version | string | No description |
networking.subnet_type | string | Deploy to internal subnets (cannot reach the internet) or private subnets (internet egress traffic allowed) |
observability.enable_cloudwatch_logs_export | boolean | No description |
observability.enhanced_monitoring_interval | integer | Monitor the operating system of DB instances in real time. Enhanced Monitoring is stored in Cloudwatch Logs and may incur additional changes. Learn more |
observability.performance_insights_retention_period | integer | Performance Insights is a database performance tuning and monitoring feature that helps you quickly assess the load on your database, and determine when and where to take action. Performance Insights allows non-experts to detect performance problems with an easy-to-understand dashboard that visualizes database load. |