How to deploy Nuxt JS on Kubernetes Cluster (Part 1)

Omegion
3 min readMar 21, 2021

A tutorial about dockerizing Nuxt.js application to be deployed on Kubernetes cluster in minutes.

Introduction

Kubernetes is a fully managed container …

I am a big fan of Nuxt.js, recently created my personal blog where you read this post. I decided to host my personal blog Nuxt.js application on my self-managed Kubernetes cluster. On the way of deployment, I gained quite an amount of experience how to containerize a Nuxt.js application.

Since Nuxt.js supports full static application, our Nuxt.js application will be around 50MB, which is great!

Prerequisites

Before you get started, you will need to have a number of things.

  1. yarn

Install Nuxt.js

yarn create nuxt-app nuxt-k8s
create-nuxt-app v3.6.0
✨ Generating Nuxt.js project in nuxt-k8s
? Project name: nuxt-k8s
? Programming language: TypeScript
? Package manager: Yarn
? UI framework: Buefy
? Nuxt.js modules:
? Linting tools: (Press <space> to select, <a> to toggle all, <i> to invert selection)
? Testing framework: None
? Rendering mode: Universal (SSR / SSG)
? Deployment target: Static (Static/Jamstack hosting)
? Development tools: (Press <space> to select, <a> to toggle all, <i> to invert selection)
? What is your GitHub username?
? Version control system: Git

Running Nuxt Application

Now, let’s run our application with:

cd nuxt-k8s
yarn run dev

If you access localhost:3000 you will see the application.

Dockerization

Every application that runs on Kubernetes is nothing but a container. So, we need to create Dockerfile our Nuxt.js application. For this tutorial, we will deploy a fully static website. Eventually, Nuxt.js has already a built-in mechanism to generate our static files.

Our Dockerfile will have two main stages. The first stage will install dependencies and generate static files, the second stage will serve these static files with Nginx.

Let’s create Dockerfile in the application codebase.

touch Dockerfile

Paste the following content in the created file.

Dockerfile

# Build Stage
FROM node:lts-alpine as build-stage
ENV NODE_ENV=production
ENV APP_HOME=/usr/src/app
RUN mkdir -p $APP_HOMECOPY . $APP_HOMERUN cd $APP_HOME && yarn install \
--prefer-offline \
--pure-lockfile \
--non-interactive \
--production=true
WORKDIR $APP_HOMERUN yarn run generate# Production Stage
FROM nginx:stable-alpine as production-stage
ENV APP_HOME=/usr/src/appCOPY --from=build-stage $APP_HOME/dist /usr/share/nginx/htmlRUN chown nginx:nginx /usr/share/nginx/htmlEXPOSE 80CMD ["nginx", "-g", "daemon off;"]

Build Docker Image

Once we created our Dockerfile, now we can good to create our docker image.

docker build -t nuxt-k8s .

If everything went well, check the image and its size:

❯ docker image ls                 
REPOSITORY TAG IMAGE ID CREATED SIZE
nuxt-k8s latest c8c54ee0d07f 15 minutes ago 23.7MB

As we generate only static files of our application, we only need to put generated files to the docker image.

Test Docker Image

Now, let’s test the docker image if it can render our Nuxt.js application.

docker run -ti -p 3001:80 nuxt-k8s

If you access localhost:3001, you will access your built application.

Conclusion

In this tutorial, we created Nuxt.js with Buefy CSS framework. Then, we could create a Dockerfile multiple stages which enabled us to reduce an enormous amount of space of the docker image. Finally, we could build and test our docker image.

I am going to continue this tutorial series on the next article. We will be deploying our Nuxt.js application on the Kubernetes cluster.

How to deploy Nuxt JS on Kubernetes Cluster 2

Originally published at https://omegion.dev/how-to-run-nuxt-on-kubernetes-1

--

--