Chris.luChris.lu header image, displaying an 80s style landscape and sunset

Production release

This part of the tutorial covers three important things when going into production with a new project. First, we will do a production build and deploy it using Vercel. Next, we will use Vercel's nice feature, Open Graph previews, to check if our Open Graph metadata produces the expected result. Finally, we will add a custom domain name to our project.

Vercel alternatives

In this tutorial, we deploy to Vercel, but there are a lot of alternatives to chose from.

Tip

Next.js 15 comes with improvements to self hosting make it easier for you to chose and alternative to Vercel

For example one alternative to Vercel is Deno Deploy which has support for Next.js (both static and SSR)

Or as this is a static project you could also deploy your project to GitHub pages (using the Next.js export configuration option) or you could deploy your static assets using the CDN of your favorite cloud provider.

If you want to mimic Vercel and build your own serverless infrastructure, then you should look into services like AWS Lambda or Cloudflare Workers

Production deployment

First, make sure all code is committed in the review branch

Wait for the review to deploy on Vercel

Check the preview to make sure everything works as intended

Then go to github.com (and if you are not yet logged in, log in)

Open your repository page

Create a pull request to merge the code from the preview branch into the main (production) branch

Wait for all potential GitHub actions to finish checking your build, and when the bottom box, including the merge button, are all green (because all checks have passed successfully), click on merge

When merged, Vercel will start a production deployment

After the build is ready, we use our projects vercel.app production domain to make a last test of our website or blog

Open Graph previews on Vercel

You can try out the Vercel Open Graph Simulator that can display Open Graph previews for a multitude of social networks and messengers

Visit vercel.com (and then log in if you are not yet logged in), click on your project, and then in the top navigation, click on Deployments

Then click on the 3 dots on the right for your latest production deployment and then select Inspect deployment

On the Deployment Details page you will have a new top navigation, click on Open Graph

On the right side, you have the preview, and above the preview there are Icons that represent the different services you can simulate, just click on the icons to switch between them

On the left you can see what open graph the Simulator found in your source code, you can switch between pages by changing the Pathname on top

Adding a custom domain for production to Vercel using nameservers

Visit vercel.com (and then log in if you are not yet logged in)

You are now on your overview page, in the navigation bar (of your account), you have a section called Domains, click on it to access the domains management page

If this is the first domain, in the middle of the page there are two options, to buy or to transfer a domain, but on top there is a third add option

different options on the vercel domains page

If you already added a domain, the page will look a bit differently, but you will still have 3 options on top, Buy, Add Existing, and Transfer In

I already own a domain and I see no reason why I would transfer it, as all my domains are at the same registrar and I would like to keep it like that, so I will chose add a domain

After clicking on add, a modal box will appear and ask you to choose your project, so do just that and then click on Continue

Next, add your domain name into the input field and click on Add

Now Vercel will launch a check, which obviously will fail 🤦, they tell us that your nameserver configuration is Invalid, well it is not invalid it is just that we haven't updated them yet. This step is a bit weird as it is doomed to fail. However, this is how they tell you to do it on the nameservers documentation page, there is even a warning in which they tell you to first add the domain to the project. At least we now know what the new nameservers are, that we need to use for the configuration on the website of our domain registrar

It doesn't matter if you add the domain to vercel first and then do the nameserver update or first use their nameservers, as you can find all the information you need in their nameserver documentation page

The two nameservers Vercel tells us to use are:

ns1.vercel-dns.com
ns2.vercel-dns.com

So now you need to visit the website of your registrar and Edit the nameservers for your domain, wait for the nameservers update to finish (you either have a status box on the registrar website or get a notification telling you when it is done), this notification is only to tell you that the registrar has made the change, for all worldwide DNS servers to get the update will take some time (worst case scenario is 24h, usually it is a lot less)

Now go back to vercel.com, then click on the project for which you want to add a domain

Then in the project navigation bar (on top) click on Settings

On the Project Settings page, in the navigation on the left, click on domains

Now vercel will check again and there is a chance it will also fail again, this is because it takes some time for the DNS Propagation to happen, this can take several hours (sometimes up to 48 hours, but it is usually shorter)

You can use an online tool like dnschecker to check the DNS Propagation for your domain, in the dropdown list choose NS to check for the nameservers

Note

Vercel generates a Let’s Encrypt ssl certificate for you when you add a domain, meaning all your domains will automatically serve content over a HTTPS connection

After release task list

First, congratulations on the release 🎉 it is finally done, time to let others have a look at what you have been working all this time

Some tasks you might want to perform to quickly make sure the release was a success:

Tip

At some point (wait a few days to be sure everything is ok)

  • If there are NO CSP violations, you will want to set the CSP variable cspReportOnly (in the next.config.mjs file) to false to start enforcing CSP directives
  • You might want to start posting about new project on social media and maybe start advertising your project to increase traffic