Compute and Disk
Compute
Every project on the Supabase Platform comes with its own dedicated Postgres instance.
The following table describes the base instances, Nano (free plan) and Micro (paid plans), with additional compute instance sizes available if you need extra performance when scaling up.
Nano instances in Pro organizations
In Pro organizations, Nano Compute are billed at the same price as Micro Compute. It is recommended to upgrade your Project from Nano Compute to Micro Compute when it's convenient for you. Compute sizes are not auto-upgraded because of the downtime incurred. See Supabase Pricing for more information.
Compute Size | Hourly Price USD | Monthly Price USD | CPU | Memory | Max DB Size (Recommended)1 |
---|---|---|---|---|---|
Nano2 | $0 | $0 | Shared | Up to 0.5 GB | 500 MB |
Micro | $0.01344 | ~$10 | 2-core ARM (shared) | 1 GB | 10 GB |
Small | $0.0206 | ~$15 | 2-core ARM (shared) | 2 GB | 50 GB |
Medium | $0.0822 | ~$60 | 2-core ARM (shared) | 4 GB | 100 GB |
Large | $0.1517 | ~$110 | 2-core ARM (dedicated) | 8 GB | 200 GB |
XL | $0.2877 | ~$210 | 4-core ARM (dedicated) | 16 GB | 500 GB |
2XL | $0.562 | ~$410 | 8-core ARM (dedicated) | 32 GB | 1 TB |
4XL | $1.32 | ~$960 | 16-core ARM (dedicated) | 64 GB | 2 TB |
8XL | $2.562 | ~$1,870 | 32-core ARM (dedicated) | 128 GB | 4 TB |
12XL | $3.836 | ~$2,800 | 48-core ARM (dedicated) | 192 GB | 6 TB |
16XL | $5.12 | ~$3,730 | 64-core ARM (dedicated) | 256 GB | 10 TB |
Compute sizes can be changed by first selecting your project in the dashboard here and the upgrade process will incur downtime.
We charge hourly for additional compute based on your usage. Read more about usage-based billing for compute.
Dedicated vs shared CPU
All Postgres databases on Supabase run in isolated environments. Compute instances smaller than Large
compute size have CPUs which can burst to higher performance levels for short periods of time. Instances bigger than Large
have predictable performance levels and do not exhibit the same burst behavior.
Compute upgrades
Compute instance changes are usually applied with less than 2 minutes of downtime, but can take longer depending on the underlying Cloud Provider.
When considering compute upgrades, assess whether your bottlenecks are hardware-constrained or software-constrained. For example, you may want to look into optimizing the number of connections or examining query performance. When you're happy with your Postgres instance's performance, then you can focus on additional compute resources. For example, you can load test your application in staging to understand your compute requirements. You can also start out on a smaller tier, create a report in the Dashboard to monitor your CPU utilization, and upgrade as needed.
Disk
Supabase databases are backed by high performance SSD disks. The effective performance depends on a combination of all the following factors:
- Compute size
- Provisioned Disk Throughput
- Provisioned Disk IOPS: Input/Output Operations per Second, which measures the number of read and write operations.
- Disk type: io2 or gp3
- Disk size
The disk size and the disk type dictate the maximum IOPS and throughput that can be provisioned. The effective IOPS is the lower of the IOPS supported by the compute size or the provisioned IOPS of the disk. Similarly, the effective throughout is the lower of the throughput supported by the compute size and the provisioned throughput of the disk.
The following sections explain how these attributes affect disk performance.
Compute size
The compute size of your project sets the upper limit for disk throughput and IOPS. The table below shows the limits for each instance size. For instance, an 8XL compute instance has a maximum throughput of 9,500 MiB/s and a maximum IOPS of 40,000.
Compute Instance | Disk Throughput | IOPS |
---|---|---|
Nano (free) | 43 MiB/s | 250 IOPS |
Micro | 87 MiB/s | 500 IOPS |
Small | 174 MiB/s | 1,000 IOPS |
Medium | 347 MiB/s | 2,000 IOPS |
Large | 630 MiB/s | 3,600 IOPS |
XL | 1,188 MiB/s | 6,000 IOPS |
2XL | 2,375 MiB/s | 12,000 IOPS |
4XL | 4,750 MiB/s | 20,000 IOPS |
8XL | 9,500 MiB/s | 40,000 IOPS |
12XL | 14,250 MiB/s | 50,000 IOPS |
16XL | 19,000 MiB/s | 80,000 IOPS |
Smaller compute instances like Nano, Micro, and Small have baseline performance levels that can occasionally be exceeded. Larger compute-instances (4XL and above) are designed for sustained, high performance with specific IOPS and throughput limits. If you hit your IOPS or throughput limit, throttling will occur.
Choosing the right compute instance for consistent disk performance
If you need consistent disk performance, choose the 4XL or larger compute instance. If you're unsure of how much throughput or IOPS your application requires, you can load test your project and inspect these metrics in the Dashboard. If the Disk IO % consumed
stat is more than 1%, it indicates that your workload has exceeded the baseline IO throughput during the day. If this metric goes to 100%, the workload has used up all available disk IO budget. Projects that use any disk IO budget are good candidates for upgrading to a larger compute instance with higher throughput.
Provisioned Disk throughput and IOPS
The default disk type is gp3, which comes with a baseline throughput of 125 MiB/s and a default IOPS of 3,000. You can provision additional IOPS and throughput from the Database Settings page, but keep in mind that the effective IOPS and throughput will be limited by the compute instance size.
Be aware that increasing IOPS or throughput incurs additional charges.
Disk types
When selecting your disk, it's essential to focus on the performance needs of your workload. Here's a comparison of our available disk types:
General Purpose SSD (gp3) | High Performance SSD (io2) | |
---|---|---|
Use Case | General workloads, development environments, small to medium databases | High-performance needs, large-scale databases, mission-critical applications |
Max Disk Size | 16 TB | 60 TB |
Max IOPS | 16,000 IOPS (at 32 GB disk size) | 80,000 IOPS (at 80 GB disk size) |
Throughput | 125 MiB/s (default) to 1,000 MiB/s (maximum) | Automatically scales with IOPS |
Best For | Great value for most use cases | Low latency and very high IOPS requirements |
For general, day-to-day operations, gp3 should be more than enough. If you need high throughput and IOPS for critical systems, io2 will provide the performance required.
Compute instance size changes will not change your selected disk type or disk size, but your IO limits may change according to what your selected compute instance size supports.
Disk size
- General Purpose (gp3) disks come with a baseline of 3,000 IOPS and 125 MiB/s. You can provision additional 500 IOPS for every GB of disk size and additional 0.25 MiB/s throughput per provisioned IOPS.
- High Performance (io2) disks can be provisioned with 1,000 IOPS per GB of disk size.
Limits and Constraints
Postgres replication slots, WAL senders, and connections
Replication Slots and WAL Senders are used to enable Postgres Replication. Each compute instance also has limits on the maximum number of database connections and connection pooler clients it can handle.
The maximum number of replication slots, WAL senders, database connections, and pooler clients depends on your compute instance size, as follows:
Compute instance | Max Replication Slots | Max WAL Senders | Database Max Connections3 | Connection Pooler Max Clients |
---|---|---|---|---|
Nano (free) | 5 | 5 | 60 | 200 |
Micro | 5 | 5 | 60 | 200 |
Small | 5 | 5 | 90 | 400 |
Medium | 5 | 5 | 120 | 600 |
Large | 8 | 8 | 160 | 800 |
XL | 24 | 24 | 240 | 1,000 |
2XL | 80 | 80 | 380 | 1,500 |
4XL | 80 | 80 | 480 | 3,000 |
8XL | 80 | 80 | 490 | 6,000 |
12XL | 80 | 80 | 500 | 9,000 |
16XL | 80 | 80 | 500 | 12,000 |
As mentioned in the Postgres documentation, setting max_replication_slots
to a lower value than the current number of replication slots will prevent the server from starting. If you are downgrading your compute instance, ensure that you are using fewer slots than the maximum number of replication slots available for the new compute instance.
Constraints
- After any disk attribute change, there is a cooldown period of approximately six hours before you can make further adjustments. During this time, no changes are allowed. If you encounter throttling, you’ll need to wait until the cooldown period concludes before making additional modifications.
- You can increase disk size but cannot decrease it.
Footnotes
-
Database size for each compute instance is the default recommendation but the actual performance of your database has many contributing factors, including resources available to it and the size of the data contained within it. See the shared responsibility model for more information. ↩
-
Compute resources on the Free plan are subject to change. ↩
-
Database max connections are recommended values and can be customized depending on your use case. ↩