Namespace
alpine
Image / Tag
openclaw:2026.5.2-beta.2-slim
Content Digest
sha256:b00b26116a188dd53cd7d5610f3f8f71aaab0a96b73d05f65f9e4168f58b7e85
Details
Created

2026-05-02 21:33:08 UTC

Size

662 MB

Content Digest
Labels
  • org.opencontainers.image.base.digest
    sha256:e8e2e91b1378f83c5b2dd15f0247f34110e2fe895f6ca7719dbb780f929368eb
  • org.opencontainers.image.base.name
    docker.io/library/node:24-bookworm-slim
  • org.opencontainers.image.created
    2026-05-02T21:30:53Z
  • org.opencontainers.image.description
    OpenClaw gateway and CLI runtime container image
  • org.opencontainers.image.documentation
    https://docs.openclaw.ai/install/docker
  • org.opencontainers.image.licenses
    MIT
  • org.opencontainers.image.revision
    1c0babdea830696b28715bf8e8bb7d7bae064df6
  • org.opencontainers.image.source
    https://github.com/openclaw/openclaw
  • org.opencontainers.image.title
    OpenClaw
  • org.opencontainers.image.url
    https://openclaw.ai
  • org.opencontainers.image.version
    2026.5.2-beta.2

Environment
COREPACK_HOME

/usr/local/share/corepack

NODE_ENV

production

NODE_VERSION

24.14.0

PATH

/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

YARN_VERSION

1.22.22


Layers

[#000] sha256:84a2afebaf4de2e8eb885634a69abd0087b79c947c53fa4f0481235d6dfadc6c - 4.07% (26.9 MB)

[#001] sha256:2f65248ca12c731590966502324732fc1f0cfa22622a00950064e65e87b2f9f0 - 0.0% (3.24 KB)

[#002] sha256:24c453db3621c449574826d4cf7243759451878bac6ca0ccad0be051ac852237 - 7.09% (47 MB)

[#003] sha256:add91cf7b2c0c5e486cb854d472bf259b54dd5d0240026aa1de856e404f09242 - 0.25% (1.63 MB)

[#004] sha256:95df4b7d52358ca06d5e717d5365e23f63c0da7199abf508b40673f883e0d6b9 - 0.0% (447 Bytes)

[#005] sha256:c99cd83ad967fa2cd544bf2239653bc46564958e9caac939cfae654b4b734b98 - 0.0% (93 Bytes)

[#006] sha256:309909eda993e2a4b378b00f5666c1209a5e09b1ec3b213dd9a239ee6deab476 - 6.72% (44.5 MB)

[#007] sha256:3ca50c7c82fd17748d7ccc2f498f8603b1222490d389f271eb3ece2ebdb1a892 - 0.0% (94 Bytes)

[#008] sha256:7796be25a0e18f35cc0204b5143a643d01d3c333fa85d742521d9795914056e1 - 2.63% (17.4 MB)

[#009] sha256:bc4e612ef78be9e2c161a3d3f6951fe2db7982598332fb3cf30af83723da607a - 76.03% (503 MB)

[#010] sha256:e513dbc37d8d6cbb55617b15ea0a4746ebd51869977837016402e48e97413bfb - 0.0% (13.8 KB)

[#011] sha256:11e122fa6cb5223b37ade5417ea299a0e5aede15494abf5b46efc9bc86124f76 - 0.0% (1.72 KB)

[#012] sha256:6f3da92ca1a4269786b56ccef3a304f33867069e70d42b35e04f377c251b0a7b - 0.0% (2.82 KB)

[#013] sha256:e9385f8e541436c3f8db915510a513829405405841735c15999ff4db35ccfbd7 - 1.25% (8.25 MB)

[#014] sha256:445c26fe23bb4849fe1529a8989dbd0c13e560a5079dc0f6f999dd671872e660 - 0.01% (97.2 KB)

[#015] sha256:8758c00f9a18c309bbddab9f333364ee1d51cbc1570076280cd7829b7ee9618a - 1.26% (8.33 MB)

[#016] sha256:386d6b30bbc1d8d5f5f0e18ff2495ea9177e968711253f351ab95ab1672ef91d - 0.01% (79.8 KB)

[#017] sha256:043c7db6f0e881c1ceee017d4b9e2e99302046c0cea15d99ea3f300cc7c00cb3 - 0.68% (4.53 MB)

[#018] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)

[#019] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)

[#020] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)

[#021] sha256:3a2aef48992a35eb94936aa31bade0c1c6905b1429fb7be86c0e05fb650e4f45 - 0.0% (184 Bytes)

[#022] sha256:1a77929692c5810b5280d46f6633d22e62a433c2277ad5647d151d7e1060e159 - 0.0% (151 Bytes)


History
2026-02-23 00:00:00 UTC (debuerreotype 0.17)

# debian.sh --arch 'amd64' out/ 'bookworm' '@1771804800'

2026-02-24 20:14:54 UTC (buildkit.dockerfile.v0)

RUN /bin/sh -c groupadd --gid 1000 node && useradd --uid 1000 --gid node --shell /bin/bash --create-home node # buildkit

2026-02-24 20:15:15 UTC (buildkit.dockerfile.v0)

ENV NODE_VERSION=24.14.0

2026-02-24 20:15:15 UTC (buildkit.dockerfile.v0)

RUN /bin/sh -c ARCH= OPENSSL_ARCH= && dpkgArch="$(dpkg --print-architecture)" && case "${dpkgArch##*-}" in amd64) ARCH='x64' OPENSSL_ARCH='linux-x86_64';; ppc64el) ARCH='ppc64le' OPENSSL_ARCH='linux-ppc64le';; s390x) ARCH='s390x' OPENSSL_ARCH='linux*-s390x';; arm64) ARCH='arm64' OPENSSL_ARCH='linux-aarch64';; armhf) ARCH='armv7l' OPENSSL_ARCH='linux-armv4';; i386) ARCH='x86' OPENSSL_ARCH='linux-elf';; *) echo "unsupported architecture"; exit 1 ;; esac && set -ex && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr xz-utils libatomic1 --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 5BE8A3F6C8A5C01D106C0AD820B1A390B168D356 DD792F5973C6DE52C432CBDAC77ABFA00DDBF2B7 CC68F5A3106FF448322E48ED27F5E38D5B0A215F 8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 890C08DB8579162FEE0DF9DB8BEAB4DFCF555EF4 C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C 108F52B48DB57BB0CC439B2997B01419BD92F80A A363A499291CBBC940DD62E41F10027AF002F8B0 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc && gpgconf --kill all && rm -rf "$GNUPGHOME" && grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - && tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner && rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt && find /usr/local/include/node/openssl/archs -mindepth 1 -maxdepth 1 ! -name "$OPENSSL_ARCH" -exec rm -rf {} \; && apt-mark auto '.*' > /dev/null && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && ln -s /usr/local/bin/node /usr/local/bin/nodejs && node --version && npm --version && rm -rf /tmp/* # buildkit

2026-02-24 20:15:15 UTC (buildkit.dockerfile.v0)

ENV YARN_VERSION=1.22.22

2026-02-24 20:15:29 UTC (buildkit.dockerfile.v0)

RUN /bin/sh -c set -ex && savedAptMark="$(apt-mark showmanual)" && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 6A010C5166006599AA17F08146C2130DFD2497F5 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && gpgconf --kill all && rm -rf "$GNUPGHOME" && mkdir -p /opt && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && apt-mark auto '.*' > /dev/null && { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark > /dev/null; } && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && yarn --version && rm -rf /tmp/* # buildkit

2026-02-24 20:15:29 UTC (buildkit.dockerfile.v0)

COPY docker-entrypoint.sh /usr/local/bin/ # buildkit

2026-02-24 20:15:29 UTC (buildkit.dockerfile.v0)

ENTRYPOINT ["docker-entrypoint.sh"]

2026-02-24 20:15:29 UTC (buildkit.dockerfile.v0)

CMD ["node"]

2026-05-02 20:41:35 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_NODE_BOOKWORM_SLIM_DIGEST

2026-05-02 20:41:35 UTC (buildkit.dockerfile.v0)

LABEL org.opencontainers.image.base.name=docker.io/library/node:24-bookworm-slim org.opencontainers.image.base.digest=sha256:e8e2e91b1378f83c5b2dd15f0247f34110e2fe895f6ca7719dbb780f929368eb

2026-05-02 20:41:35 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_BUNDLED_PLUGIN_DIR

2026-05-02 20:41:35 UTC (buildkit.dockerfile.v0)

LABEL org.opencontainers.image.source=https://github.com/openclaw/openclaw org.opencontainers.image.url=https://openclaw.ai org.opencontainers.image.documentation=https://docs.openclaw.ai/install/docker org.opencontainers.image.licenses=MIT org.opencontainers.image.title=OpenClaw org.opencontainers.image.description=OpenClaw gateway and CLI runtime container image

2026-05-02 20:41:35 UTC (buildkit.dockerfile.v0)

WORKDIR /app

2026-05-02 20:41:49 UTC (buildkit.dockerfile.v0)

RUN |1 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions /bin/sh -c apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends ca-certificates procps hostname curl git lsof openssl python3 && update-ca-certificates # buildkit

2026-05-02 20:41:49 UTC (buildkit.dockerfile.v0)

RUN |1 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions /bin/sh -c chown node:node /app # buildkit

2026-05-02 21:32:58 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/dist ./dist # buildkit

2026-05-02 21:33:06 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/node_modules ./node_modules # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/package.json . # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/patches ./patches # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/openclaw.mjs . # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/extensions ./extensions # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/skills ./skills # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/docs ./docs # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/qa ./qa # buildkit

2026-05-02 21:33:07 UTC (buildkit.dockerfile.v0)

ENV COREPACK_HOME=/usr/local/share/corepack

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

RUN |1 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions /bin/sh -c install -d -m 0755 "$COREPACK_HOME" && corepack enable && for attempt in 1 2 3 4 5; do if corepack prepare "$(node -p "require('./package.json').packageManager")" --activate; then break; fi; if [ "$attempt" -eq 5 ]; then exit 1; fi; sleep $((attempt * 2)); done && chmod -R a+rX "$COREPACK_HOME" # buildkit

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_DOCKER_APT_PACKAGES=

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

RUN |2 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= /bin/sh -c if [ -n "$OPENCLAW_DOCKER_APT_PACKAGES" ]; then apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends $OPENCLAW_DOCKER_APT_PACKAGES; fi # buildkit

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_INSTALL_BROWSER=

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

RUN |3 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= /bin/sh -c if [ -n "$OPENCLAW_INSTALL_BROWSER" ]; then apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends xvfb && mkdir -p /home/node/.cache/ms-playwright && PLAYWRIGHT_BROWSERS_PATH=/home/node/.cache/ms-playwright node /app/node_modules/playwright-core/cli.js install --with-deps chromium && chown -R node:node /home/node/.cache/ms-playwright; fi # buildkit

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_INSTALL_DOCKER_CLI=

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

RUN |5 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= OPENCLAW_INSTALL_DOCKER_CLI= OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88 /bin/sh -c if [ -n "$OPENCLAW_INSTALL_DOCKER_CLI" ]; then apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends ca-certificates curl gnupg && install -m 0755 -d /etc/apt/keyrings && curl -fsSL https://download.docker.com/linux/debian/gpg -o /tmp/docker.gpg.asc && expected_fingerprint="$(printf '%s' "$OPENCLAW_DOCKER_GPG_FINGERPRINT" | tr '[:lower:]' '[:upper:]' | tr -d '[:space:]')" && docker_gpg_pub_count="$(gpg --batch --show-keys --with-colons /tmp/docker.gpg.asc | awk -F: '$1 == "pub" { c++ } END { print c+0 }')" && if [ "$docker_gpg_pub_count" != "1" ]; then echo "ERROR: Docker apt key must contain exactly one public key (found $docker_gpg_pub_count); refusing a multi-key file." >&2; exit 1; fi && actual_fingerprint="$(gpg --batch --show-keys --with-colons /tmp/docker.gpg.asc | awk -F: '$1 == "fpr" { print toupper($10); exit }')" && if [ -z "$actual_fingerprint" ] || [ "$actual_fingerprint" != "$expected_fingerprint" ]; then echo "ERROR: Docker apt key fingerprint mismatch (expected $expected_fingerprint, got ${actual_fingerprint:-<empty>})" >&2; exit 1; fi && gpg --dearmor -o /etc/apt/keyrings/docker.gpg /tmp/docker.gpg.asc && rm -f /tmp/docker.gpg.asc && chmod a+r /etc/apt/keyrings/docker.gpg && printf 'deb [arch=%s signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian bookworm stable\n' "$(dpkg --print-architecture)" > /etc/apt/sources.list.d/docker.list && apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends docker-ce-cli docker-compose-plugin; fi # buildkit

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

RUN |5 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= OPENCLAW_INSTALL_DOCKER_CLI= OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88 /bin/sh -c ln -sf /app/openclaw.mjs /usr/local/bin/openclaw && chmod 755 /app/openclaw.mjs # buildkit

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

RUN |5 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= OPENCLAW_INSTALL_DOCKER_CLI= OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88 /bin/sh -c install -d -m 0700 -o node -g node /home/node/.openclaw && stat -c '%U:%G %a' /home/node/.openclaw | grep -qx 'node:node 700' # buildkit

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

ENV NODE_ENV=production

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

USER node

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

HEALTHCHECK &{["CMD-SHELL" "node -e \"fetch('http://127.0.0.1:18789/healthz').then((r)=>process.exit(r.ok?0:1)).catch(()=>process.exit(1))\""] "3m0s" "10s" "15s" "0s" '\x03'}

2026-05-02 21:33:08 UTC (buildkit.dockerfile.v0)

CMD ["node" "openclaw.mjs" "gateway" "--allow-unconfigured"]

Details
Created

2026-05-02 21:33:46 UTC

Size

654 MB

Content Digest
Labels
  • org.opencontainers.image.base.digest
    sha256:e8e2e91b1378f83c5b2dd15f0247f34110e2fe895f6ca7719dbb780f929368eb
  • org.opencontainers.image.base.name
    docker.io/library/node:24-bookworm-slim
  • org.opencontainers.image.created
    2026-05-02T21:30:43Z
  • org.opencontainers.image.description
    OpenClaw gateway and CLI runtime container image
  • org.opencontainers.image.documentation
    https://docs.openclaw.ai/install/docker
  • org.opencontainers.image.licenses
    MIT
  • org.opencontainers.image.revision
    1c0babdea830696b28715bf8e8bb7d7bae064df6
  • org.opencontainers.image.source
    https://github.com/openclaw/openclaw
  • org.opencontainers.image.title
    OpenClaw
  • org.opencontainers.image.url
    https://openclaw.ai
  • org.opencontainers.image.version
    2026.5.2-beta.2

Environment
COREPACK_HOME

/usr/local/share/corepack

NODE_ENV

production

NODE_VERSION

24.14.0

PATH

/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

YARN_VERSION

1.22.22


Layers

[#000] sha256:eb04ef52de3a23999fcda632f100324a4d1dbebd588b4df190c4a172bb88c603 - 4.1% (26.8 MB)

[#001] sha256:0ddaa54706fa44d506ec734ade18fd5503c094f4c3dbd9f34dcbb0a1f2ff20c9 - 0.0% (3.24 KB)

[#002] sha256:43a62db3740c6a9f1f4ae243e10e5b019674f77eb9c5c9df15ed3947047e21d9 - 7.18% (47 MB)

[#003] sha256:1f36ab8ba95710a39d66b02c86d8133d46fbd9e76ebe3c56514aba663ad421de - 0.25% (1.63 MB)

[#004] sha256:f2d25284b17eefbd06bf6674e4c27147594e6f1860280c2e6d1248b2f1bdc52a - 0.0% (447 Bytes)

[#005] sha256:93d6bd9f6a81d4f741f5bf08d11d1e68b85edc767e21e311308666aee667c82a - 0.0% (93 Bytes)

[#006] sha256:8d7ff9b2597e4aa560b86a715fca2c1b757bb40e53bb9308e9ba74a779eacd75 - 6.8% (44.5 MB)

[#007] sha256:c527bbed5610fc0f6b562e973d98ee53cf93d8a0c01c8109d4a83696cfd18815 - 0.0% (96 Bytes)

[#008] sha256:d5455d5dc7d16b4768710fbdcb9c16e5131c55ad49fdd050379afefadd6f7158 - 2.66% (17.4 MB)

[#009] sha256:8e259a5826b7742be946fb5806258a2acc5d1a5025a723660de64fe72f6c69fb - 75.75% (495 MB)

[#010] sha256:77f024eacc9293332ceed693a2963cfe6c20989c7fbc14ca1dc0f8b50553527d - 0.0% (13.8 KB)

[#011] sha256:9def0c245cbbdc446edbee42fb80c66ceba309b255e9dd116af3e59dd2b5ac2b - 0.0% (1.73 KB)

[#012] sha256:846bac686701e4ccdf50a1aeed684c5c1bcc423f7e308b7af19555a5af6d6f7c - 0.0% (2.82 KB)

[#013] sha256:758d89818f2bfa4e05021ddc1d83b2dc19afa1bd20e4988ded20ce184162aa45 - 1.26% (8.25 MB)

[#014] sha256:4953a4d180087c33d13fc12c1ff4c42786939c50bdc7bc1a726842c562d7289b - 0.01% (97.3 KB)

[#015] sha256:6932734da089314ee534b7592f0f259bc112388490da556fb2b2fbc48f4d50a0 - 1.27% (8.33 MB)

[#016] sha256:10ebe4e55f51f9afbb76b27595d2d094236e6c73581e301f51d4891e1eeda28b - 0.01% (79.8 KB)

[#017] sha256:3ba7a15ba63d0dc952efdc223abf02adb5218eeec77eff7deaebe4d0290488a5 - 0.69% (4.53 MB)

[#018] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)

[#019] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)

[#020] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)

[#021] sha256:312e3576c7c251c86db3b09dca8aebdf6c89f16cf9ec9aa00ead432c9e1ce167 - 0.0% (182 Bytes)

[#022] sha256:bc740506adfce0b8150c7153eef2554499534bcc2f155a4642c6ffcf629340ba - 0.0% (152 Bytes)


History
2026-02-23 00:00:00 UTC (debuerreotype 0.17)

# debian.sh --arch 'arm64' out/ 'bookworm' '@1771804800'

2026-02-24 19:31:41 UTC (buildkit.dockerfile.v0)

RUN /bin/sh -c groupadd --gid 1000 node && useradd --uid 1000 --gid node --shell /bin/bash --create-home node # buildkit

2026-02-24 20:27:40 UTC (buildkit.dockerfile.v0)

ENV NODE_VERSION=24.14.0

2026-02-24 20:27:40 UTC (buildkit.dockerfile.v0)

RUN /bin/sh -c ARCH= OPENSSL_ARCH= && dpkgArch="$(dpkg --print-architecture)" && case "${dpkgArch##*-}" in amd64) ARCH='x64' OPENSSL_ARCH='linux-x86_64';; ppc64el) ARCH='ppc64le' OPENSSL_ARCH='linux-ppc64le';; s390x) ARCH='s390x' OPENSSL_ARCH='linux*-s390x';; arm64) ARCH='arm64' OPENSSL_ARCH='linux-aarch64';; armhf) ARCH='armv7l' OPENSSL_ARCH='linux-armv4';; i386) ARCH='x86' OPENSSL_ARCH='linux-elf';; *) echo "unsupported architecture"; exit 1 ;; esac && set -ex && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr xz-utils libatomic1 --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 5BE8A3F6C8A5C01D106C0AD820B1A390B168D356 DD792F5973C6DE52C432CBDAC77ABFA00DDBF2B7 CC68F5A3106FF448322E48ED27F5E38D5B0A215F 8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 890C08DB8579162FEE0DF9DB8BEAB4DFCF555EF4 C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C 108F52B48DB57BB0CC439B2997B01419BD92F80A A363A499291CBBC940DD62E41F10027AF002F8B0 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc && gpgconf --kill all && rm -rf "$GNUPGHOME" && grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - && tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner && rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt && find /usr/local/include/node/openssl/archs -mindepth 1 -maxdepth 1 ! -name "$OPENSSL_ARCH" -exec rm -rf {} \; && apt-mark auto '.*' > /dev/null && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && ln -s /usr/local/bin/node /usr/local/bin/nodejs && node --version && npm --version && rm -rf /tmp/* # buildkit

2026-02-24 20:27:40 UTC (buildkit.dockerfile.v0)

ENV YARN_VERSION=1.22.22

2026-02-24 20:27:52 UTC (buildkit.dockerfile.v0)

RUN /bin/sh -c set -ex && savedAptMark="$(apt-mark showmanual)" && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 6A010C5166006599AA17F08146C2130DFD2497F5 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && gpgconf --kill all && rm -rf "$GNUPGHOME" && mkdir -p /opt && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && apt-mark auto '.*' > /dev/null && { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark > /dev/null; } && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && yarn --version && rm -rf /tmp/* # buildkit

2026-02-24 20:27:52 UTC (buildkit.dockerfile.v0)

COPY docker-entrypoint.sh /usr/local/bin/ # buildkit

2026-02-24 20:27:52 UTC (buildkit.dockerfile.v0)

ENTRYPOINT ["docker-entrypoint.sh"]

2026-02-24 20:27:52 UTC (buildkit.dockerfile.v0)

CMD ["node"]

2026-05-02 20:41:47 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_NODE_BOOKWORM_SLIM_DIGEST

2026-05-02 20:41:47 UTC (buildkit.dockerfile.v0)

LABEL org.opencontainers.image.base.name=docker.io/library/node:24-bookworm-slim org.opencontainers.image.base.digest=sha256:e8e2e91b1378f83c5b2dd15f0247f34110e2fe895f6ca7719dbb780f929368eb

2026-05-02 20:41:47 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_BUNDLED_PLUGIN_DIR

2026-05-02 20:41:47 UTC (buildkit.dockerfile.v0)

LABEL org.opencontainers.image.source=https://github.com/openclaw/openclaw org.opencontainers.image.url=https://openclaw.ai org.opencontainers.image.documentation=https://docs.openclaw.ai/install/docker org.opencontainers.image.licenses=MIT org.opencontainers.image.title=OpenClaw org.opencontainers.image.description=OpenClaw gateway and CLI runtime container image

2026-05-02 20:41:47 UTC (buildkit.dockerfile.v0)

WORKDIR /app

2026-05-02 20:42:44 UTC (buildkit.dockerfile.v0)

RUN |1 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions /bin/sh -c apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends ca-certificates procps hostname curl git lsof openssl python3 && update-ca-certificates # buildkit

2026-05-02 20:42:44 UTC (buildkit.dockerfile.v0)

RUN |1 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions /bin/sh -c chown node:node /app # buildkit

2026-05-02 21:33:28 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/dist ./dist # buildkit

2026-05-02 21:33:43 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/node_modules ./node_modules # buildkit

2026-05-02 21:33:43 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/package.json . # buildkit

2026-05-02 21:33:43 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/patches ./patches # buildkit

2026-05-02 21:33:43 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/openclaw.mjs . # buildkit

2026-05-02 21:33:44 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/extensions ./extensions # buildkit

2026-05-02 21:33:45 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/skills ./skills # buildkit

2026-05-02 21:33:45 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/docs ./docs # buildkit

2026-05-02 21:33:45 UTC (buildkit.dockerfile.v0)

COPY --chown=node:node /app/qa ./qa # buildkit

2026-05-02 21:33:45 UTC (buildkit.dockerfile.v0)

ENV COREPACK_HOME=/usr/local/share/corepack

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

RUN |1 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions /bin/sh -c install -d -m 0755 "$COREPACK_HOME" && corepack enable && for attempt in 1 2 3 4 5; do if corepack prepare "$(node -p "require('./package.json').packageManager")" --activate; then break; fi; if [ "$attempt" -eq 5 ]; then exit 1; fi; sleep $((attempt * 2)); done && chmod -R a+rX "$COREPACK_HOME" # buildkit

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_DOCKER_APT_PACKAGES=

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

RUN |2 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= /bin/sh -c if [ -n "$OPENCLAW_DOCKER_APT_PACKAGES" ]; then apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends $OPENCLAW_DOCKER_APT_PACKAGES; fi # buildkit

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_INSTALL_BROWSER=

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

RUN |3 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= /bin/sh -c if [ -n "$OPENCLAW_INSTALL_BROWSER" ]; then apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends xvfb && mkdir -p /home/node/.cache/ms-playwright && PLAYWRIGHT_BROWSERS_PATH=/home/node/.cache/ms-playwright node /app/node_modules/playwright-core/cli.js install --with-deps chromium && chown -R node:node /home/node/.cache/ms-playwright; fi # buildkit

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_INSTALL_DOCKER_CLI=

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

ARG OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

RUN |5 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= OPENCLAW_INSTALL_DOCKER_CLI= OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88 /bin/sh -c if [ -n "$OPENCLAW_INSTALL_DOCKER_CLI" ]; then apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends ca-certificates curl gnupg && install -m 0755 -d /etc/apt/keyrings && curl -fsSL https://download.docker.com/linux/debian/gpg -o /tmp/docker.gpg.asc && expected_fingerprint="$(printf '%s' "$OPENCLAW_DOCKER_GPG_FINGERPRINT" | tr '[:lower:]' '[:upper:]' | tr -d '[:space:]')" && docker_gpg_pub_count="$(gpg --batch --show-keys --with-colons /tmp/docker.gpg.asc | awk -F: '$1 == "pub" { c++ } END { print c+0 }')" && if [ "$docker_gpg_pub_count" != "1" ]; then echo "ERROR: Docker apt key must contain exactly one public key (found $docker_gpg_pub_count); refusing a multi-key file." >&2; exit 1; fi && actual_fingerprint="$(gpg --batch --show-keys --with-colons /tmp/docker.gpg.asc | awk -F: '$1 == "fpr" { print toupper($10); exit }')" && if [ -z "$actual_fingerprint" ] || [ "$actual_fingerprint" != "$expected_fingerprint" ]; then echo "ERROR: Docker apt key fingerprint mismatch (expected $expected_fingerprint, got ${actual_fingerprint:-<empty>})" >&2; exit 1; fi && gpg --dearmor -o /etc/apt/keyrings/docker.gpg /tmp/docker.gpg.asc && rm -f /tmp/docker.gpg.asc && chmod a+r /etc/apt/keyrings/docker.gpg && printf 'deb [arch=%s signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian bookworm stable\n' "$(dpkg --print-architecture)" > /etc/apt/sources.list.d/docker.list && apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends docker-ce-cli docker-compose-plugin; fi # buildkit

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

RUN |5 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= OPENCLAW_INSTALL_DOCKER_CLI= OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88 /bin/sh -c ln -sf /app/openclaw.mjs /usr/local/bin/openclaw && chmod 755 /app/openclaw.mjs # buildkit

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

RUN |5 OPENCLAW_BUNDLED_PLUGIN_DIR=extensions OPENCLAW_DOCKER_APT_PACKAGES= OPENCLAW_INSTALL_BROWSER= OPENCLAW_INSTALL_DOCKER_CLI= OPENCLAW_DOCKER_GPG_FINGERPRINT=9DC858229FC7DD38854AE2D88D81803C0EBFCD88 /bin/sh -c install -d -m 0700 -o node -g node /home/node/.openclaw && stat -c '%U:%G %a' /home/node/.openclaw | grep -qx 'node:node 700' # buildkit

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

ENV NODE_ENV=production

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

USER node

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

HEALTHCHECK &{["CMD-SHELL" "node -e \"fetch('http://127.0.0.1:18789/healthz').then((r)=>process.exit(r.ok?0:1)).catch(()=>process.exit(1))\""] "3m0s" "10s" "15s" "0s" '\x03'}

2026-05-02 21:33:46 UTC (buildkit.dockerfile.v0)

CMD ["node" "openclaw.mjs" "gateway" "--allow-unconfigured"]

Danger Zone
Delete Tag

Please be careful as this will not just delete the reference but also the actual content!

For example when you have latest and v1.2.3 both pointing to the same image
the deletion of latest will also permanently remove v1.2.3.

Delete