How to deploy the Next.js App + Middleware template

The Next.js App + Middleware accelerates the deployment of a Next.js application with custom configurations, App Router, and a middleware to run it directly on the edge.

This template deploys a basic Next.js application containing a domain to access the Single-Page Application (SPA), an Object Storage configuration, cache settings, Gzip compression, and Rules Engine rules to improve the performance and delivery of static files. Additionally, it creates a new GitHub repository, including a GitHub Action to enable a continuous development workflow and keep your application up to date.

Next.js App + Middleware creates files to implement the App Router format, with the index page, edge API routing, and Custom Route Handler created in the new repository during the deployment. It also includes a middleware that allows you to modify the response for a request and control different aspects of the application, such as performing redirects, setting headers, and others.

This template uses Next version 13.5.6.


Requirements

To use this template, you need:

  • A GitHub account to connect with Azion and create your new repository.
    • Every push will be deployed automatically to this repository to keep your project updated.
  • This template uses Application Accelerator and Functions, and it may generate usage-related costs. Check the pricing page for more information.

Deploying the template

You can obtain and configure your template through the Azion Console. To easily deploy it at the edge, click the button below.

Deploy

Setting up the template

In the configuration form, you must provide the information to configure your application. Fill in the presented fields.

Fields identified with an asterisk are mandatory.

  1. Connect Azion with your GitHub account.
  • A pop-up window will open to confirm the installation of the Azion GitHub App, a tool that connects your GitHub account with Azion’s platform.
  • Define your permissions and repository access as desired.
  1. Select the Git Scope to work with.
  2. Define a name for your application.
  • The bucket for storage and the edge function will use the same name.
  • Use a unique and easy-to-remember name. If the name has already been used, the platform returns an error message.
  1. Click the Deploy button to start the deployment process.

During the deployment, you’ll be able to follow the process through a window showing the logs. When it’s complete, the page shows information about the application and some options to continue your journey.


Managing the template

Considering that this initial setup may not be optimal for your specific application, all settings can be customized any time you need through Azion Console.

To manage and edit your application’s settings, proceed as follows:

  1. Access Azion Console > Applications.
  • You’ll be redirected to the Applications page. It lists all the applications you’ve created.
  1. Select the application related to this template.
  • The list is organized alphabetically. You can also use the search bar located in the upper-left corner of the list; currently, it filters only by Application Name.

After selecting the application you’ll work on, you’ll be directed to a page containing all the settings you can configure.

Adding a custom domain

The application created during the deployment has an assigned Azion Workload domain to make it accessible through the browser. The domain has the following format: xxxxxxxxxx.map.azionedge.net/. However, you can add a custom domain for users to access your application through it.

Go to configuring a domain guide