Multi-architecture distroless Node.js Docker images.
- The Node.js binary, statically linked using musl, with opt-in support for i18n data
- The musl dynamic linker, to support native modules
- A
/etc/passwd
entry for anode
user
Multi-architecture images for amd64
, arm32v6
, arm32v7
and arm64v8
:
latest
,14
,14.14
,14.14.0
– 15.3 MB / 41.0 MB13
,13.14
,13.14.0
– 14.8 MB / 39.0 MB12
,12.18
,12.18.3
– 14.6 MB / 39.0 MB10
,10.22
,10.22.0
– 13.3 MB / 34.1 MB8
,8.17
,8.17.0
– 11.2 MB / 30.1 MB
The image sizes are compressed / unpacked. They are published to the following repositories:
- docker.io/astefanutti/scratch-node
- ghcr.io/astefanutti/scratch-node
- quay.io/astefanutti/scratch-node
FROM node as builder
WORKDIR /app
COPY package.json package-lock.json index.js ./
RUN npm install --prod
FROM astefanutti/scratch-node
COPY --from=builder /app /
ENTRYPOINT ["node", "index.js"]
Native modules need to be statically compiled with musl to be loadable. This can easily be achieved by updating the above example with:
FROM node:alpine as builder
RUN apk update && apk add make g++ python
WORKDIR /app
COPY package.json package-lock.json index.js ./
RUN LDFLAGS='-static-libgcc -static-libstdc++' npm install --build-from-source=<native_module>
FROM astefanutti/scratch-node
COPY --from=builder /app /
ENTRYPOINT ["node", "index.js"]
The Node binaries are link against the ICU library statically, and include a subset of ICU data (typically only the English locale) to keep the images size small. Additional locale data can be provided if needed, so that the JS methods would work for all ICU locales. it can be made available to ICU by retrieving the locales data from the ICU sources, e.g.:
FROM alpine as builder
RUN apk update && apk add curl
# Note the exact version of icu4c that's compatible depends on the Node version!
RUN curl -Lsq -o icu4c-67_1-src.zip https://github.com/unicode-org/icu/releases/download/release-67-1/icu4c-67_1-src.zip \
&& unzip -q icu4c-67_1-src.zip
FROM astefanutti/scratch-node:14.14.0
COPY --from=builder /icu/source/data/in/icudt67l.dat /icu/
ENV NODE_ICU_DATA=/icu
More information can be found in the Providing ICU data at runtime from the Node.js documentation.
The image can be built by executing the following commands:
$ git clone https://github.com/astefanutti/scratch-node
& cd scratch-node
$ docker build --build-arg version=<nodejs_version> --build-arg arch=<target_architecture> .