2026-02-25 08:15:27 UTC
344 MB
production
NODE_VERSION24.14.0
PATH/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
TZAsia/Shanghai
YARN_VERSION1.22.22
[#000] sha256:7edd3f021dc7e1b3c318b5ccfdd1677d38bb02df32bd6865c4c67be1cdc843b0 - 6.66% (22.9 MB)
[#001] sha256:e94cbbf6a6bb134b724f67efef18c006ae39c4275c81105e01d5c0b2d33c1bed - 0.0% (3.31 KB)
[#002] sha256:2055fcd44c7b4d10ff4e835a1ca2c2d15a03f11921b625d9ba8571c4697cc4f5 - 12.6% (43.3 MB)
[#003] sha256:86516089fd529ddcc4c8637e59a030fe5574a71276ebc532d8284791369e64dc - 0.43% (1.46 MB)
[#004] sha256:7ade40182e512e9ef19fcdf118a146c4983a9c7a556da7406772e0f1b0796bc3 - 0.0% (426 Bytes)
[#005] sha256:a12a148dd082e4862709918a093483732d7d660d868b003dc5558b22bba78146 - 0.0% (85 Bytes)
[#006] sha256:ec0f05c448d7b9d881f582a1e515db2f481b6ec79c56586356ead749bcc860a3 - 30.79% (106 MB)
[#007] sha256:a8e91d401407a7096b1aa4fc5d375ae4fa5c1641315c85f3e39a3ef561b5fa08 - 43.41% (149 MB)
[#008] sha256:2f7012abe0517fdb9e20c7ce31317c911fb00065c612fed3641165b9fa65f917 - 0.0% (212 Bytes)
[#009] sha256:5032e6dc0085153f8d9a3bdc3df822f46ad94e186b6dfad3d72b938655cdee9b - 6.12% (21 MB)
# 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-02-25 08:09:18 UTC (buildkit.dockerfile.v0)LABEL org.opencontainers.image.authors=https://github.com/DIYgod/RSSHub
2026-02-25 08:09:18 UTC (buildkit.dockerfile.v0)ENV NODE_ENV=production
2026-02-25 08:09:18 UTC (buildkit.dockerfile.v0)ENV TZ=Asia/Shanghai
2026-02-25 08:09:18 UTC (buildkit.dockerfile.v0)WORKDIR /app
2026-02-25 08:09:18 UTC (buildkit.dockerfile.v0)ARG TARGETPLATFORM=linux/amd64
2026-02-25 08:09:18 UTC (buildkit.dockerfile.v0)ARG PUPPETEER_SKIP_DOWNLOAD=0
2026-02-25 08:15:24 UTC (buildkit.dockerfile.v0)RUN |2 TARGETPLATFORM=linux/amd64 PUPPETEER_SKIP_DOWNLOAD=0 /bin/sh -c set -ex && apt-get update && apt-get install -yq --no-install-recommends dumb-init git curl ; if [ "$PUPPETEER_SKIP_DOWNLOAD" = 0 ]; then if [ "$TARGETPLATFORM" = 'linux/amd64' ]; then apt-get install -yq --no-install-recommends ca-certificates fonts-liberation wget xdg-utils libasound2 libatk-bridge2.0-0 libatk1.0-0 libatspi2.0-0 libcairo2 libcups2 libdbus-1-3 libdrm2 libexpat1 libgbm1 libglib2.0-0 libnspr4 libnss3 libpango-1.0-0 libx11-6 libxcb1 libxcomposite1 libxdamage1 libxext6 libxfixes3 libxkbcommon0 libxrandr2 ; else apt-get install -yq --no-install-recommends chromium && echo "CHROMIUM_EXECUTABLE_PATH=$(which chromium)" | tee /app/.env ; fi; apt-get install -yq --no-install-recommends xvfb procps ; fi; rm -rf /var/lib/apt/lists/* # buildkit
2026-02-25 08:15:25 UTC (buildkit.dockerfile.v0)COPY /app/node_modules/.cache/puppeteer /app/node_modules/.cache/puppeteer # buildkit
2026-02-25 08:15:25 UTC (buildkit.dockerfile.v0)RUN |2 TARGETPLATFORM=linux/amd64 PUPPETEER_SKIP_DOWNLOAD=0 /bin/sh -c set -ex && if [ "$PUPPETEER_SKIP_DOWNLOAD" = 0 ] && [ "$TARGETPLATFORM" = 'linux/amd64' ]; then echo 'Verifying Chromium installation...' && _chrome_path=$(find /app/node_modules/.cache/puppeteer/chrome/ -name chrome -xtype f -executable | head -n1) && echo "CHROMIUM_EXECUTABLE_PATH=$_chrome_path" | tee /app/.env && if ldd "$_chrome_path" | grep "not found"; then echo "!!! Chromium has unmet shared libs !!!" && exit 1 ; else echo "Awesome! All shared libs are met!" ; fi; fi; # buildkit
2026-02-25 08:15:27 UTC (buildkit.dockerfile.v0)COPY /app /app # buildkit
2026-02-25 08:15:27 UTC (buildkit.dockerfile.v0)EXPOSE [1200/tcp]
2026-02-25 08:15:27 UTC (buildkit.dockerfile.v0)ENTRYPOINT ["dumb-init" "--"]
2026-02-25 08:15:27 UTC (buildkit.dockerfile.v0)CMD ["npm" "run" "start"]
2026-02-25 08:15:28 UTC
339 MB
production
NODE_VERSION24.14.0
PATH/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
TZAsia/Shanghai
YARN_VERSION1.22.22
[#000] sha256:6a648222dc59267ecbbfed293a7f60b3e80990efb479b7546b827108ddacbdd3 - 6.52% (22.1 MB)
[#001] sha256:57af8ee7e9f102920f7c51c283d8991ca9f72788c81ae739692f9e4dee4f3235 - 0.0% (3.31 KB)
[#002] sha256:6c7322e0097e1f95ab9680170a5c066cfdf55310f22a24515106569beb576120 - 12.77% (43.3 MB)
[#003] sha256:4ac6880615681a73d73f68d20ddf996fb66dee197081be599f282b1590383a12 - 0.43% (1.46 MB)
[#004] sha256:0e8f343566d4f6397dbe85933f5e027d7de42fe2ec46e90cd8c24d0c76770b48 - 0.0% (425 Bytes)
[#005] sha256:0bed33e884612e3fa012d1b641cd3d88a2a1fe1d3c31822b470bb728e75b5650 - 0.0% (85 Bytes)
[#006] sha256:a0fba1064bc76ba33f06f3b18d72662024ad263372a8d4f408b1ac27279e584f - 74.07% (251 MB)
[#007] sha256:6250b2bfd05ff5ffe29df93d4ac0853fad03f4a50d8c0f0312bf34fa64ebc3c9 - 0.0% (153 Bytes)
[#008] sha256:2c1ce468d9f3d941396801f6e3afc8921466650dd05430fe644cd3537713d27f - 0.0% (16 Bytes)
[#009] sha256:3a003e85807a996a01c8c6b936cf250e7775ac706c90a8fda7164eb1b8d79d7c - 6.21% (21.1 MB)
# 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-02-25 08:10:09 UTC (buildkit.dockerfile.v0)LABEL org.opencontainers.image.authors=https://github.com/DIYgod/RSSHub
2026-02-25 08:10:09 UTC (buildkit.dockerfile.v0)ENV NODE_ENV=production
2026-02-25 08:10:09 UTC (buildkit.dockerfile.v0)ENV TZ=Asia/Shanghai
2026-02-25 08:10:09 UTC (buildkit.dockerfile.v0)WORKDIR /app
2026-02-25 08:10:09 UTC (buildkit.dockerfile.v0)ARG TARGETPLATFORM=linux/arm64
2026-02-25 08:10:09 UTC (buildkit.dockerfile.v0)ARG PUPPETEER_SKIP_DOWNLOAD=0
2026-02-25 08:15:25 UTC (buildkit.dockerfile.v0)RUN |2 TARGETPLATFORM=linux/arm64 PUPPETEER_SKIP_DOWNLOAD=0 /bin/sh -c set -ex && apt-get update && apt-get install -yq --no-install-recommends dumb-init git curl ; if [ "$PUPPETEER_SKIP_DOWNLOAD" = 0 ]; then if [ "$TARGETPLATFORM" = 'linux/amd64' ]; then apt-get install -yq --no-install-recommends ca-certificates fonts-liberation wget xdg-utils libasound2 libatk-bridge2.0-0 libatk1.0-0 libatspi2.0-0 libcairo2 libcups2 libdbus-1-3 libdrm2 libexpat1 libgbm1 libglib2.0-0 libnspr4 libnss3 libpango-1.0-0 libx11-6 libxcb1 libxcomposite1 libxdamage1 libxext6 libxfixes3 libxkbcommon0 libxrandr2 ; else apt-get install -yq --no-install-recommends chromium && echo "CHROMIUM_EXECUTABLE_PATH=$(which chromium)" | tee /app/.env ; fi; apt-get install -yq --no-install-recommends xvfb procps ; fi; rm -rf /var/lib/apt/lists/* # buildkit
2026-02-25 08:15:26 UTC (buildkit.dockerfile.v0)COPY /app/node_modules/.cache/puppeteer /app/node_modules/.cache/puppeteer # buildkit
2026-02-25 08:15:26 UTC (buildkit.dockerfile.v0)RUN |2 TARGETPLATFORM=linux/arm64 PUPPETEER_SKIP_DOWNLOAD=0 /bin/sh -c set -ex && if [ "$PUPPETEER_SKIP_DOWNLOAD" = 0 ] && [ "$TARGETPLATFORM" = 'linux/amd64' ]; then echo 'Verifying Chromium installation...' && _chrome_path=$(find /app/node_modules/.cache/puppeteer/chrome/ -name chrome -xtype f -executable | head -n1) && echo "CHROMIUM_EXECUTABLE_PATH=$_chrome_path" | tee /app/.env && if ldd "$_chrome_path" | grep "not found"; then echo "!!! Chromium has unmet shared libs !!!" && exit 1 ; else echo "Awesome! All shared libs are met!" ; fi; fi; # buildkit
2026-02-25 08:15:28 UTC (buildkit.dockerfile.v0)COPY /app /app # buildkit
2026-02-25 08:15:28 UTC (buildkit.dockerfile.v0)EXPOSE [1200/tcp]
2026-02-25 08:15:28 UTC (buildkit.dockerfile.v0)ENTRYPOINT ["dumb-init" "--"]
2026-02-25 08:15:28 UTC (buildkit.dockerfile.v0)CMD ["npm" "run" "start"]