Step-by-Step Guide: How to Deploy a Next.js App on Heroku

Step-by-Step Guide: How to Deploy a Next.js App on Heroku

Deploying a Next.js application on Heroku is a straightforward process. In this guide, we will walk you through the steps required to get your Next.js app up and running on Heroku. By the end of this tutorial, you will have a live Next.js application hosted on Heroku.

Prerequisites

Before we begin, make sure you have the following installed on your local machine:

  • Node.js and npm
  • Git
  • Heroku CLI

Step 1: Create a Next.js App

If you don't already have a Next.js app, you can create one using the following command:

npx create-next-app my-nextjs-app
cd my-nextjs-app

This will create a new Next.js application in a directory called my-nextjs-app.

Step 2: Initialize a Git Repository

Navigate to your Next.js app directory and initialize a Git repository:

git init
git add .
git commit -m "Initial commit"

Step 3: Create a Heroku App

Log in to your Heroku account using the Heroku CLI:

heroku login

Once logged in, create a new Heroku app:

heroku create my-nextjs-app

Replace my-nextjs-app with a unique name for your Heroku app.

Step 4: Configure the Buildpack

Heroku uses buildpacks to determine how to build and run your application. For a Next.js app, we need to use the Node.js buildpack. Heroku automatically detects the buildpack based on the presence of a package.json file.

Step 5: Add a Procfile

Create a Procfile in the root of your project directory. This file tells Heroku how to run your application. Add the following line to the Procfile:

web: npm run start

This tells Heroku to run the start script defined in your package.json file.

Step 6: Set Environment Variables

If your Next.js app requires environment variables, you can set them using the Heroku CLI. For example:

heroku config:set NEXT_PUBLIC_API_URL=https://api.example.com

Replace NEXT_PUBLIC_API_URL with the environment variable your app needs.

Step 7: Deploy to Heroku

Now that everything is set up, you can deploy your Next.js app to Heroku. First, add the Heroku remote to your Git repository:

git remote add heroku https://git.heroku.com/my-nextjs-app.git

Replace my-nextjs-app with the name of your Heroku app.

Next, push your code to the Heroku remote:

git push heroku main

Heroku will build and deploy your application. Once the deployment is complete, you will see a message indicating that your app is live.

Step 8: Open Your App

You can open your deployed Next.js app in your browser using the following command:

heroku open

This will open your app's URL in your default web browser.

Conclusion

Congratulations! You have successfully deployed your Next.js app on Heroku. In this guide, we covered the steps to create a Next.js app, initialize a Git repository, create a Heroku app, configure the buildpack, add a Procfile, set environment variables, and deploy your app to Heroku. Now you can share your live Next.js application with the world.

If you encounter any issues or have any questions, feel free to refer to the Heroku documentation or the Next.js documentation. Happy coding!

Recent Posts