08-28-2022
- Sample Multi Zone App, powered by Vercel
- Using multiple zones
- Resources
With Next.js you can use multiple apps as a single app using its multi-zones feature. This is a custom example using the boiler-nextjs app that shows how to use it.
- All pages should be unique across zones. For example, the
home
app should not have apages/blog/index.tsx
page. - The
home
app is the main app and therefore it includes the rewrites that map to theblog
app in next.config.js - The
blog
app setsbasePath
to/blog
so that generated pages, Next.js assets and public assets are within the/blog
subfolder.
With multi zones you have multiple Next.js apps over a single app, therefore every app has its own dependencies and it runs independently.
To start the /home
run the following commands from the root directory:
cd home
npm install && npm run dev
# or
cd home
yarn && yarn dev
The /home
app should be up and running in http://localhost:3000!
Starting the /blog
app follows a very similar process. In a new terminal, run the following commands from the root directory :
cd blog
npm install && npm run dev
# or
cd blog
yarn && yarn dev
The blog
app should be up and running in http://localhost:4000!
You can deploy this app to the cloud with Vercel (Documentation).
To deploy the apps to Vercel, we'll use monorepos support to create a new project for each app.
To get started, push the example to GitHub/GitLab/Bitbucket and import your repo to Vercel. We're not interested in the root directory, so make sure to select the blog
directory (do not start with home
):
Import flow for blog app
Click continue and finish the import process. After that's done copy the domain URL that was assigned to your project, paste it on home/.env
, and push the change to your repo:
# Replace this URL with the URL of your blog app
BLOG_URL="https://multi-zones-blog.vercel.app"
Now we'll go over the import flow again using the same repo but this time select the home
directory instead:
Import flow for home app
With the home
app deployed you should now be able to see both apps running under the same domain!
Any future commits to the repo will trigger a deployment to the connected Vercel projects. See the blog post about monorepos to learn more.
NextJS - Multi Zones
- https://nextjs.org/docs/advanced-features/multi-zones
- https://www.techomoro.com/multi-zones-combine-multiple-next-js-apps/
The Evolution of SaaS Architecture - Monoliths, Micro Front-End, Jamstack
Micro-frontend with React and Next.js
Micro-Frontends
- https://www.novafutur.com/post/micro-frontends-solving-the-monolith-issue
- https://www.novafutur.com/post/micro-frontends-solving-the-monolith-issue-part-2
- https://blog.logrocket.com/taming-the-front-end-monolith-dbaede402c39/
- https://levelup.gitconnected.com/micro-frontend-architecture-replacing-a-monolith-from-the-inside-out-61f60d2e14c1
- https://martinfowler.com/articles/micro-frontends.html