Blitz is now in beta! 🎉 1.0 expected this April
Back to Documentation Menu

Deploy Serverless to Vercel

Topics

Jump to a Topic

Serverless Peculiarities for SQL Databases

There are two main issues when it comes to using SQL databases in a serverless environment:

Problem 1: Separate Locations for App and Database

Because Vercel doesn't provide databases, you will use a separate platform for your database. And therefore people accidentally deploy their app to a different region than their database.

Solution: Deploy your app and database to the same region. By default Vercel apps are deployed to Washington D.C., so your database should be as close as possible to that.

Problem 2: Idle Connections

Ideally you will set up your database client and database connection outside your API handler (this is the default setup in Blitz apps). This optimizes performance because subsequent requests to the same lambda already have an active database connection.

However, this can result in a large number of idle connections. A larger number than what your database can support. For reference, the lowest database tier on Digital Ocean has a limit of 22 connections.

Solution: The solution to this problem is to use a connection pool in front of your database. Pgbouncer is the most popular connection pool for postgres. Both Digital Ocean and Heroku have a feature to simply add pgbouncer.

Problem 3: Database Throughput

Pgbouncer for PostgreSQL is advertised as allowing you to have 5,000-10,000 active database connections, but it's critical to understand that those are idle connections. Pgbouncer does not increase your core database capacity. If your database has a max of 22 connections, then you can only have 22 simultaneous transactions, regardless of whether you have pgbouncer in front of it or not.

Solution: Increase your database size to meet the traffic needs for your app. But be aware this can become very expensive.

Note: slow database transactions will greatly decrease your throughput. If it seems you are running out of connections before you should based on your app traffic, then turn on logging for your database queries and look for long transactions.

Databases to Consider

  1. PostgreSQL + Pgbouncer
  2. PlanetScaleDB - This is MySQL but seems to have solved the connection limit issue for serverless environments

Guide for Using Digital Ocean with Vercel

This assumes your Blitz app is already set up for Postgres. If it's not, first follow these instructions

This also assumes you already have a Vercel account.

  1. You need a production Postgres database. It's straightforward to set this up on Digital Ocean.
    1. It's extremely important that you choose the DB location to be in the same region as your Vercel deployment. By default Vercel deployments are in Washington D.C., so you should choose the closest Digital Ocean location which is New York City.
  2. You also need a connection pool. This is also relatively straightforward to set up on Digital Ocean.
    1. Read the Digital Ocean docs on setting up your connection pool
    2. Ensure you set your "Pool Mode" to be "Transaction"
  3. You need your entire database connection string. If you need, read the Prisma docs on this.
    1. Make sure you get the connection string to your connection pool, not directly to the DB.
    2. If using pgBouncer (default connection pool on Digital Ocean), you must add &pgbouncer=true to the end of your connection string for Prisma to work correctly.
  4. Change your build script in package.json to be NODE_ENV=production blitz build && blitz prisma migrate deploy --preview-feature so that the production DB will be migrated on each deploy
  5. Add your DB url as a secret environment variable using the UI or by running vercel env add DATABASE_URL
  6. Add your SESSION_SECRET_KEY environment variable (It needs to be 32 characters long)
    • On macOS and Linux, you can generate it by running openssl rand -hex 16 in your terminal.
  7. Run git push if using the Git Integration or vercel if using Vercel CLI

Idea for improving this page? Edit it on Github.