Skip to content

Latest commit

 

History

History
186 lines (130 loc) · 5.84 KB

docker.md

File metadata and controls

186 lines (130 loc) · 5.84 KB

Docker

Introduction

A docker example with a multi-stage approach to minimize image size and build time (taking advantage of buildx cache).

.
├── apps
│   └── nextjs-app
├── packages
│   ├── core-lib
│   ├── db-main-prisma
│   └── ui-lib
├── static
│   ├── assets
│   └── locales
├── .dockerignore
├── docker-compose.nextjs-app.yml  (specific for nextjs-app)
├── docker-compose.yml             (general services like postgresql...)
└── Dockerfile                     (multistage build for nextjs-app)

Requirements

Note: Be sure to create a .dockerignore containing at least those entries.

Ready made commands

Yarn script Description
yarn docker:nextjs-app:develop Run apps/nextjs-app in development mode
yarn docker:nextjs-app:install Install dependencies in cache mount
yarn docker:nextjs-app:build Create a production build
yarn docker:nextjs-app:serve Serve production build on localhost:3000,
yarn docker:prune-cache Run this regularly if using in local !!!

Build and serve commands requires to have a ./apps/nextjs-app/.env.local present.

Develop

yarn docker:nextjs-app:develop

# Or alternatively
DOCKER_BUILDKIT=1 docker-compose -f ./docker-compose.yml -f ./docker-compose.nextjs-app.yml up develop main-db
Want to open a shell to debug ?
DOCKER_BUILDKIT=1 docker-compose -f ./docker-compose.nextjs-app.yml run --rm develop sh

Multistage in details

See the latest ./docker-compose.nextjs-app.yml and ./Dockerfile.

PS: The goal of multistage is mainly to reduce the size of the resulting image, it also allows to skip deps stage (ie: install deps) when no changes are detected in your deps (lock file).

Lazydocker multistage sizes

Stage 1: deps

This stage will install the monorepo and make all node_modules folders available in later stages.

Some commands

To build it independently

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml build --progress=tty deps
# docker buildx bake -f docker-compose.nextjs-app.yml --progress=tty deps

To force a rebuild

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml build --no-cache --force-rm --progress=tty deps

Want to open a shell into it ?

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml run --rm deps sh

Stage 2: builder

This stage will automatically run the deps stage and copy all installed node_modules folder. Then build the thing and remove devDependencies.

PS: You'll have to send some build-args (env variables) in order to have a real build.

Some commands To build it independently
DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml build --progress=tty builder
# docker buildx bake -f docker-compose.nextjs-app.yml --progress=tty builder

To force a rebuild

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml build --no-cache --force-rm --progress=tty builder

Want to open a shell into it ?

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml run --rm builder sh

Stage 3: runner

Launch a production build and listen by default to http://localhost:3000.

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml --env-file .env.secret up runner

PS: you'll have to provide your own .env with required runtime variables.

Some commands To build it independently
DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml build --progress=tty runner
# docker buildx bake -f docker-compose.nextjs-app.yml --progress=tty runner

To force a rebuild

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml build --no-cache --force-rm --progress=tty runner

Want to open a shell into it ?

DOCKER_BUILDKIT=1 docker-compose -f docker-compose.nextjs-app.yml run --rm runner sh

Remove docker

Cleanup

Option Command
Prune buildx docker buildx prune
Prune cachemount caches docker builder prune --filter type=exec.cachemount
Remove all containers docker container rm -f $(docker container ls -qa)
Clean all images docker image rm -f $(docker image ls -q)
Remove all volumes docker volume rm $(docker volume ls -q)

Complete removal

Like to remove all docker layers, overlays... Warning you'll lose all your data.

systemctl docker stop
rm -rd /var/lib/docker
systemctl docker start