Issue Running Puppeteer with Docker and NodeJS

I am trying to use Puppeteer and NodeJS to build my wasp-lang(https://wasp-lang.dev/) project. The NodeJS and ReactJS were building successfully but after adding Puppeteer, the app deployed successfully but refuses to work, after setting dumpio to true to see Puppeteer logs, I am getting the below error:


ERROR:bus.cc(399)] Failed to connect to the bus: Failed to connect to socket /var/run/dbus/system_bus_socket: No such file or directory

ERROR:chrome_browser_cloud_management_controller.cc(162)] Cloud management controller initialization aborted as CBCM is not enabled.

 Extension not supported: VK_KHR_surface
2024-02-19T00:34:08Z app[6e82de19f40398] mia [info][470:470:0219/003408.333496:ERROR:angle_platform_impl.cc(43)] RendererVk.cpp:157 (VerifyExtensionsPresent): Extension not supported: VK_KHR_xcb_surface

My docker file looks similar to the below:

I launch Puppeteer in My NodeJS app with:

    const browser = await puppeteer.launch({
      executablePath: '/usr/bin/chromium-browser',
      args: ['--no-sandbox'],
      dumpio: true,
    });

How do I resolve this issue to deploy my project and continue building?

Below is my Docker file:

# NOTE: Why do we specify alpine version here?

# Because if not, we had situations where it would use the different version

# locally and on Github CI. This way we ensure exact version is used,

# and also have control over updating it (instead of update surprising us).

FROM node:18-alpine3.17 AS node

# We split Dockerfile into base, server-builder and server-production.

# This way we have separate situations -> in server-builder we build all

# we need to run the server, and then in server-production we start fresh

# and just copy what we need from server-builder, avoiding intermediate

# artifacts and any settings / pollution we don't need in production

# but only for building.

FROM node AS base

RUN apk --no-cache -U upgrade # To ensure any potential security patches are applied.

FROM base AS server-builder

RUN apk add --no-cache build-base libtool autoconf automake

WORKDIR /app

COPY server/ ./server/

# Install npm packages, resulting in node_modules/.

RUN cd server && npm install

COPY db/schema.prisma ./db/

RUN cd server && PRISMA_CLIENT_OUTPUT_DIR=../server/node_modules/.prisma/client/ npx prisma generate --schema="../db/schema.prisma"

# Building the server should come after Prisma generation.

RUN cd server && npm run build

# TODO: Use pm2?

# TODO: Use non-root user (node).

FROM base AS server-production

RUN apk add --no-cache \

chromium \

nss \

freetype \

freetype-dev \

harfbuzz \

ca-certificates \

ttf-freefont \

nodejs \

yarn \

dbus \

glib \

fontconfig \

&& apk add --no-cache --virtual .build-deps \

msttcorefonts-installer \

&& update-ms-fonts \

&& fc-cache -f

# Clean up to reduce image size after installing dependencies

RUN apk del .build-deps

# Set Puppeteer environment variables to skip downloading Chromium and use the system-provided binary

ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD true

ENV PUPPETEER_EXECUTABLE_PATH /usr/bin/chromium-browser

# In case they want to use python3 in their app.

RUN apk add --no-cache python3

ENV NODE_ENV production

WORKDIR /app

COPY --from=server-builder /app/server/node_modules ./server/node_modules

COPY --from=server-builder /app/server/dist ./server/dist

COPY --from=server-builder /app/server/package*.json ./server/

COPY --from=server-builder /app/server/scripts ./server/scripts

COPY --from=server-builder /app/server/src/ext-src/api/templates ./server/templates

COPY db/ ./db/

EXPOSE ${PORT}

WORKDIR /app/server

ENTRYPOINT ["npm", "run", "start-production"]

The app build successfully but just the Puppeteer refuses to run with the above logs, I don’t know If I am missing any dependencies.

Leave a Comment