Use Neon with Koyeb
Learn how to connect a Neon Postgres database to an application deployed with Koyeb
Koyeb is a developer-friendly, serverless platform designed to easily deploy reliable and scalable applications globally. Koyeb offers native autoscaling, automatic HTTPS (SSL), auto-healing, and global load-balancing across their edge network with zero configuration.
This guide describes how connect a Neon Postgres database to an application deployed with Koyeb. To follow the instructions in this guide, you require:
- A Koyeb account to deploy the application. Alternatively, you can install the Koyeb CLI if you prefer to deploy the application from your terminal.
- A Neon account to deploy the Postgres database. If you do not have one, see Sign up.
The example application connects to your Neon Postgres database using Prisma as an ORM. Prisma synchronizes the database schema with the Prisma schema included with the application and seeds the database.
Create a Neon project
- Navigate to the Neon Console.
- Select Create a project.
- Enter a name for the project (neon-koyeb, for example), and select a Postgres version and region.
- Click Create project.
A dialog pops up with your Neon connection string, which appears similar to the following:
Store this value in a safe place. It is required later. The connection string specifies neondb as the database. This is the ready-to-use database created with each Neon project. You will use this database with the example application.
Deploy the application on Koyeb
You can deploy on Koyeb using the control panel or the Koyeb CLI.
From the Koyeb control panel
To deploy the application from the Koyeb control panel, follow these steps:
- Select Create App.
- Select GitHub as the deployment method.
- Enter https://github.com/koyeb/example-express-prismain the Public GitHub repository field.
- Keep example-express-prismaas the name andmainas the branch.
- In Build and deployment settings, enable the Override setting and add the following Build command: npm run postgres:init
- Select the region closest to your Neon database.
- Under Advanced > Environment variables, add a DATABASE_URLenvironment variable to enable the application to connect to your Neon Postgres database. Set the value to the Neon connection string provided to you when you created the Neon project.
- Enter a name for your app. For example, express-neon
- Click Deploy.
Koyeb builds the application. After the build and deployment have finished, you can access your application running on Koyeb by clicking the URL ending with .koyeb.app.
The example application exposes a /planets endpoint that you can use to list planets from the database. After your deployment is live, you should see the following results when navigating to https://<YOUR_APP_URL>.koyeb.app/planets:
From the Koyeb CLI
The Koyeb CLI requires an API access token, which you can generate in the Koyeb control panel, under Account > API.
To deploy the example application using the Koyeb CLI, run the following command in your terminal.
Make sure to replace [user], [password], and [host] with your Neon connection string values.
Access Koyeb deployment logs
To track the app deployment and visualize build logs, execute the following command:
Access your app
After the build and deployment have finished, you can retrieve the public domain to access your application by running the following command:
The example application exposes a /planets endpoint that you can use to list planets from the database. After your deployment is live, you should see the following results when navigating to https://<YOUR_APP_URL>.koyeb.app/planets:
Delete the example application and Neon project
To delete the example application on Koyeb to avoid incurring any charges, follow these steps:
- From the Koyeb control panel, select the App to delete.
- On the Settings tab, select Danger Zone and click Delete.
To delete your Neon project, refer to Delete a project.
Last updated on