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!