# Overview

DBaaS for PostgreSQL is fully integrated into the [<mark style="color:blue;">**Data Center Designer**</mark>](https://docs.ionos.com/cloud/set-up-ionos-cloud/data-center-designer) and has dedicated **APIs**: [<mark style="color:blue;">**PostgreSQL Cloud API (2.0.0)**</mark>](https://api.ionos.com/docs/postgresql/v2.ea/) and [<mark style="color:blue;">**PostgreSQL REST API (1.0.0)**</mark>](https://api.ionos.com/docs/postgresql/v1/). You may also launch it via automation tools like [<mark style="color:blue;">**Terraform**</mark>](https://docs.ionos.com/terraform-provider) and [<mark style="color:blue;">**Ansible**</mark>](https://docs.ionos.com/ansible/api/dbaas-postgres).

**Compatibility:** DBaaS gives you access to the capabilities of the PostgreSQL database engine. This means that the code, applications, and tools you already use today with your existing databases can be used with DBaaS. IONOS Cloud supports PostgreSQL versions 14, 15, and 16.

**Locations:** As of December 2022, DBaaS is offered in all IONOS Cloud Locations.

## Features

* **Scalable:** Fully managed clusters that can be scaled on demand.
* **High availability:** Multi-node clusters with automatic node failure handling.
* **Security:** Communication between clients and the cluster is encrypted using TLS certificates from Let's Encrypt.
* **Upgrades:** Customer-defined maintenance windows, with minimal disruption due to planned failover (approx. few seconds for multi-node clusters).
* **Backup:** Base backups are carried out daily, with Point-in-Time recovery for one week.
* **Cloning:** Customers also have the option to clone clusters through backups.
* **Restore:** Databases can be restored in place or to a different target cluster.
* **Resources:** Offered on Enterprise VM, with a dedicated CPU, storage, and RAM. Storage options are SSD or HDD, with SSD now including encryption-at-rest.
* **Network:** DBaaS supports private LANs.
* **Extensions:** DBaaS supports several [<mark style="color:blue;">PostgreSQL Extensions</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/activate-extensions).

## DBaaS services offered by IONOS Cloud

All back-end operations required to maintain your database in optimal operational health is supported along with the follwoing actions:

* Database installation through the DCD or the DBaaS API.
* Pre-set database configuration and configuration management options.
* Automation of backups for a period of 7 days.
* Regular patches and upgrades during maintenance.
* Disaster recovery through automated backup.
* Service monitoring: both for the database and the underlying infrastructure.

{% hint style="info" %}
**Note:** IONOS Cloud does not allow superuser access for PostgreSQL services. However, most DBA-type actions are still available through other methods.
{% endhint %}

## Customer database administration duties

Tasks related to the optimal health of the database remain the responsibility of the customer. These include:

* Optimisation
* Data organisation
* Creation of indexes
* Updating statistics
* Consultation of access plans to optimize queries

**Logs:** The database stores logs on the same disk as the database. It records connections, disconnections, lock waits, Data Definiton Language (DDL) statements, any statement that runs for at least 500 ms, and any statement that causes an error. It does not provide an option to change this configuration. For more information, refer to the [<mark style="color:blue;">PostgreSQL Documentation</mark>](https://www.postgresql.org/docs/current/runtime-config-logging.html#RUNTIME-CONFIG-LOGGING-WHAT).

To conserve disk space, log files are rotated according to size. Logs should not consume more than 175 MB of disk storage. The files are continuously monitored, and log messages are shipped to a central storage location with a 30-day retention policy. For more information, see [<mark style="color:blue;">Access Logs</mark>](https://docs.ionos.com/cloud/databases/postgresql/api/v1-api/access-logs).

**Write-Ahead Logs**: PostgreSQL uses [<mark style="color:blue;">Write Ahead Logs (WAL)</mark>](https://docs.ionos.com/cloud/support/general-information/glossary-of-terms#write-ahead-logs-wal) for continuous archiving and point-in-time recovery. These logs are created in addition to the regular logs.

Every change to the database is recorded in the WAL record. WALs are generated along with daily **base backups** and offer a consistent snapshot of the database as it was at that time. WALs and backups are automatically deleted after 7 days, which is the earliest point in time you can recover from. For more information, refer to the [<mark style="color:blue;">PostgreSQL Documentation</mark>](https://www.postgresql.org/docs/current/runtime-config-wal.html#RUNTIME-CONFIG-WAL-ARCHIVING).

**Password encryption:** Client libraries must support `SCRAM-SHA-256` authentication. Make sure to use an up-to-date client library.

**Connection encryption:** All client connections are encrypted using TLS; the default [<mark style="color:blue;">SSL mode</mark>](https://www.postgresql.org/docs/current/libpq-ssl.html#LIBPQ-SSL-PROTECTION) is `prefer` and clients cannot disable it.

Server certificates are issued by Let's Encrypt and the root certificate is `ISRG Root X1`. This needs to be made available to the client for `verify-ca` and `verify-full` to function.

Certificates are issued for the DNS name of the cluster which is assigned automatically during creation and will look similar to `pg-abc123.postgresql.de-txl.ionos.com`. It is available through the IONOS API as the `dnsName` property of the `cluster` resource.

Here is how to verify the certificate using the `psql` command line tool:

```bash
curl https://crt.sh/?q=9314791 > ca.crt
export PGSSLROOTCERT=$(pwd)/ca.crt
export PGSSLMODE=verify-full
psql -h pg-abc123.postgresql.de-txl.ionos.com -U dbadmin postgres
```

## Performance considerations

Database instances are placed in the same location as your specified LAN, so network performance should be comparable to other machines in your LAN.

**Estimates:** A test with `pgbench` (scaling factor 1000, 20 connections, duration 300 seconds, not showing detailed logs) and a single small instance (2 cores, 4 GB RAM, 20 GB HDD) resulted in around 830 transactions per second (read and write mixed) and 1100 transactions per second (read-only). For a larger instance (4 cores, 8 GB RAM, 600GB Premium SSD) the results were around 3400 (read and write) and 19000 (read-only) transactions per second. The database was initialized using `pgbench -i -s 1000 -h <ip> -U <username> <dbname>`. For benchmarking the command line used was `pgbench -c 20 -T 300 -h <ip> -U <username> <dbname>` for the read/write tests, and `pgbench -c 20 -T 300 -S -h <ip> -U <username> <dbname>` for the read-only tests.

{% hint style="info" %}
**Note:** To cite the [<mark style="color:blue;">pgbench docs</mark>](https://www.postgresql.org/docs/current/pgbench.html) : "It is very easy to use pgbench to produce completely meaningless numbers". The numbers shown here are only ballpark figures and there are no performance guarantees. The real performance will vary depending on your workload, the IONOS location, and several other factors.
{% endhint %}

## Related topics

After reviewing the overview, explore the following topics to plan and set up your PostgreSQL deployment:

* [<mark style="color:blue;">High Availability and Scaling</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/high-availability): How PostgreSQL ensures uptime and resilience through replication modes, multi-node clusters, and scaling options.
* [<mark style="color:blue;">Resource Allocation</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/resource-allocation): Guidance on choosing the right cluster size and resources for your workload.
* [<mark style="color:blue;">Failover Process</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/failover-process): How PostgreSQL handles planned and unplanned failovers, client reconnection behavior, and what to expect during node replacement.
* [<mark style="color:blue;">Maintenance Window</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/maintenance-window): How to configure scheduled maintenance periods to minimize disruption.
* [<mark style="color:blue;">Backup and Recovery</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/backup-recovery-and-migration): Strategies and options for protecting your data and restoring it when needed.
* [<mark style="color:blue;">Limitations</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/limitations): Known constraints and boundaries to be aware of when using DBaaS PostgreSQL.
* [<mark style="color:blue;">Upgrade and Maintenance</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/upgrade-maintenance): How IONOS Cloud applies patches and minor updates during maintenance windows, and what to consider when performing major PostgreSQL version upgrades.
* [<mark style="color:blue;">Activate Extensions</mark>](https://docs.ionos.com/cloud/databases/postgresql/overview/activate-extensions): How to enable supported PostgreSQL extensions in your cluster.
* [<mark style="color:blue;">Set Up a PostgreSQL Cluster</mark>](https://docs.ionos.com/cloud/databases/postgresql/how-tos/setup-a-cluster-in-the-dcd): Step-by-step instructions for provisioning and configuring a new PostgreSQL cluster.
