2026-01-13 15:05:39 UTC
497 MB
/home/frappe/.nvm
PATH/home/frappe/.nvm/versions/node/v24.12.0/bin/:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
PYTHON_SHA256ce543ab854bc256b61b71e9b27f831ffd1bfd60a479d639f8be7f9757cf573e9
PYTHON_VERSION3.14.2
[#000] sha256:c02d17997ce3d2c82e082235ea0b5152d06ee659c4e2fabcf1e0079312f1bcde - 5.42% (26.9 MB)
[#001] sha256:3e105b9f7ec01dfc23460f73aba5b0ccee03d29932bc5b3a85df01da807fab72 - 0.68% (3.35 MB)
[#002] sha256:0483e9f4d4a7fd5ba096ca43eb7f8b07b81971705aa6698a47d46910b37c631a - 2.48% (12.3 MB)
[#003] sha256:2368e38f4d2a05b07983d077975c0d4fc3b8ca109178d533e5837d40565d1a8f - 0.0% (248 Bytes)
[#004] sha256:928b9416149d8526cbeffcf51a2ed820cb6a3933bd1fb981182bf9b9bda2b337 - 51.95% (258 MB)
[#005] sha256:96b03b60eaae2994acc490df62dd3da73228e5856bfbe210bb3af2b15d0786bf - 0.0% (1.31 KB)
[#006] sha256:eebf16408b4afe6f817e6bf5b560ef0b321b09092fa8686c610f32386c950361 - 0.0% (670 Bytes)
[#007] sha256:1b58c55eef64b36fcd05413acd87edec9dbacd3bda629acfc6f7a0205c491381 - 0.0% (1.84 KB)
[#008] sha256:ee2971d8eae3948fe52676cd0937d66b2dd7a168a5873d118cfa40881fcc45dd - 39.48% (196 MB)
[#009] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)
# debian.sh --arch 'amd64' out/ 'bookworm' '@1768176000'
2026-01-13 03:04:18 UTC (buildkit.dockerfile.v0)ENV PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
2026-01-13 03:04:18 UTC (buildkit.dockerfile.v0)RUN /bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends ca-certificates netbase tzdata ; rm -rf /var/lib/apt/lists/* # buildkit
2026-01-13 03:04:18 UTC (buildkit.dockerfile.v0)ENV PYTHON_VERSION=3.14.2
2026-01-13 03:04:18 UTC (buildkit.dockerfile.v0)ENV PYTHON_SHA256=ce543ab854bc256b61b71e9b27f831ffd1bfd60a479d639f8be7f9757cf573e9
2026-01-13 03:14:02 UTC (buildkit.dockerfile.v0)RUN /bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends dpkg-dev gcc gnupg libbluetooth-dev libbz2-dev libc6-dev libdb-dev libffi-dev libgdbm-dev liblzma-dev libncursesw5-dev libreadline-dev libsqlite3-dev libssl-dev libzstd-dev make tk-dev uuid-dev wget xz-utils zlib1g-dev ; wget -O python.tar.xz "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz"; echo "$PYTHON_SHA256 *python.tar.xz" | sha256sum -c -; mkdir -p /usr/src/python; tar --extract --directory /usr/src/python --strip-components=1 --file python.tar.xz; rm python.tar.xz; cd /usr/src/python; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; ./configure --build="$gnuArch" --enable-loadable-sqlite-extensions --enable-optimizations --enable-option-checking=fatal --enable-shared $(test "${gnuArch%%-*}" != 'riscv64' && echo '--with-lto') --with-ensurepip ; nproc="$(nproc)"; EXTRA_CFLAGS="$(dpkg-buildflags --get CFLAGS)"; LDFLAGS="$(dpkg-buildflags --get LDFLAGS)"; LDFLAGS="${LDFLAGS:--Wl},--strip-all"; arch="$(dpkg --print-architecture)"; arch="${arch##*-}"; case "$arch" in amd64|arm64) EXTRA_CFLAGS="${EXTRA_CFLAGS:-} -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer"; ;; i386) ;; *) EXTRA_CFLAGS="${EXTRA_CFLAGS:-} -fno-omit-frame-pointer"; ;; esac; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:-}" ; rm python; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:--Wl},-rpath='\$\$ORIGIN/../lib'" python ; make install; cd /; rm -rf /usr/src/python; find /usr/local -depth \( \( -type d -a \( -name test -o -name tests -o -name idle_test \) \) -o \( -type f -a \( -name '*.pyc' -o -name '*.pyo' -o -name 'libpython*.a' \) \) \) -exec rm -rf '{}' + ; ldconfig; apt-mark auto '.*' > /dev/null; apt-mark manual $savedAptMark; find /usr/local -type f -executable -not \( -name '*tkinter*' \) -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); printf "*%s\n", so }' | sort -u | xargs -rt dpkg-query --search | awk 'sub(":$", "", $1) { print $1 }' | sort -u | xargs -r apt-mark manual ; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; rm -rf /var/lib/apt/lists/*; export PYTHONDONTWRITEBYTECODE=1; python3 --version; pip3 --version # buildkit
2026-01-13 03:14:02 UTC (buildkit.dockerfile.v0)RUN /bin/sh -c set -eux; for src in idle3 pip3 pydoc3 python3 python3-config; do dst="$(echo "$src" | tr -d 3)"; [ -s "/usr/local/bin/$src" ]; [ ! -e "/usr/local/bin/$dst" ]; ln -svT "$src" "/usr/local/bin/$dst"; done # buildkit
2026-01-13 03:14:02 UTC (buildkit.dockerfile.v0)CMD ["python3"]
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)ARG WKHTMLTOPDF_VERSION=0.12.6.1-3
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)ARG WKHTMLTOPDF_DISTRO=bookworm
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)ARG NODE_VERSION=24.12.0
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)ENV NVM_DIR=/home/frappe/.nvm
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)ENV PATH=/home/frappe/.nvm/versions/node/v24.12.0/bin/:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)RUN |3 WKHTMLTOPDF_VERSION=0.12.6.1-3 WKHTMLTOPDF_DISTRO=bookworm NODE_VERSION=24.12.0 /bin/sh -c useradd -ms /bin/bash frappe && apt-get update && apt-get install --no-install-recommends -y curl git vim nginx gettext-base file libpango-1.0-0 libharfbuzz0b libpangoft2-1.0-0 libpangocairo-1.0-0 restic gpg mariadb-client less libpq-dev postgresql-client wait-for-it jq media-types && mkdir -p ${NVM_DIR} && curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash && . ${NVM_DIR}/nvm.sh && nvm install ${NODE_VERSION} && nvm use v${NODE_VERSION} && npm install -g yarn && nvm alias default v${NODE_VERSION} && rm -rf ${NVM_DIR}/.cache && echo 'export NVM_DIR="/home/frappe/.nvm"' >>/home/frappe/.bashrc && echo '[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm' >>/home/frappe/.bashrc && echo '[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion' >>/home/frappe/.bashrc && if [ "$(uname -m)" = "aarch64" ]; then export ARCH=arm64; fi && if [ "$(uname -m)" = "x86_64" ]; then export ARCH=amd64; fi && downloaded_file=wkhtmltox_${WKHTMLTOPDF_VERSION}.${WKHTMLTOPDF_DISTRO}_${ARCH}.deb && curl -sLO https://github.com/wkhtmltopdf/packaging/releases/download/$WKHTMLTOPDF_VERSION/$downloaded_file && apt-get install -y ./$downloaded_file && rm $downloaded_file && rm -rf /var/lib/apt/lists/* && rm -fr /etc/nginx/sites-enabled/default && pip3 install frappe-bench && sed -i '/user www-data/d' /etc/nginx/nginx.conf && ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log && touch /run/nginx.pid && chown -R frappe:frappe /etc/nginx/conf.d && chown -R frappe:frappe /etc/nginx/nginx.conf && chown -R frappe:frappe /var/log/nginx && chown -R frappe:frappe /var/lib/nginx && chown -R frappe:frappe /run/nginx.pid # buildkit
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)COPY resources/nginx-template.conf /templates/nginx/frappe.conf.template # buildkit
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)COPY resources/nginx-entrypoint.sh /usr/local/bin/nginx-entrypoint.sh # buildkit
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)USER frappe
2026-01-13 15:04:06 UTC (buildkit.dockerfile.v0)RUN |3 WKHTMLTOPDF_VERSION=0.12.6.1-3 WKHTMLTOPDF_DISTRO=bookworm NODE_VERSION=24.12.0 /bin/sh -c echo "echo \"Commands restricted in prodution container, Read FAQ before you proceed: https://frappe.io/ctr-faq\"" >> ~/.bashrc # buildkit
2026-01-13 15:05:38 UTC (buildkit.dockerfile.v0)COPY --chown=frappe:frappe /home/frappe/frappe-bench /home/frappe/frappe-bench # buildkit
2026-01-13 15:05:39 UTC (buildkit.dockerfile.v0)WORKDIR /home/frappe/frappe-bench
2026-01-13 15:05:39 UTC (buildkit.dockerfile.v0)VOLUME [/home/frappe/frappe-bench/sites /home/frappe/frappe-bench/sites/assets /home/frappe/frappe-bench/logs]
2026-01-13 15:05:39 UTC (buildkit.dockerfile.v0)CMD ["/home/frappe/frappe-bench/env/bin/gunicorn" "--chdir=/home/frappe/frappe-bench/sites" "--bind=0.0.0.0:8000" "--threads=4" "--workers=2" "--worker-class=gthread" "--worker-tmp-dir=/dev/shm" "--timeout=120" "--preload" "frappe.app:application"]
2026-01-13 15:27:29 UTC
489 MB
/home/frappe/.nvm
PATH/home/frappe/.nvm/versions/node/v24.12.0/bin/:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
PYTHON_SHA256ce543ab854bc256b61b71e9b27f831ffd1bfd60a479d639f8be7f9757cf573e9
PYTHON_VERSION3.14.2
[#000] sha256:33bdc9671af8942d96d2f78f67aeec06580065dde1272decac3732689ec7c0e8 - 5.48% (26.8 MB)
[#001] sha256:7b6c8a12d9d0976a1da9beaeaef6d259a71d3557a39fc5c1ae58602ceec9f2ac - 0.65% (3.19 MB)
[#002] sha256:25085863c2e30c4428813c102e5856cca86a058b217201fc66d0219732de9908 - 2.5% (12.2 MB)
[#003] sha256:0ad1c38a914349cf521b6f46a745789cd837bf58215dfb79113fd677f833081b - 0.0% (249 Bytes)
[#004] sha256:84de3d2018a33f43b4955f134861c97a07f4ada290bd6f3ae875320aa049a815 - 51.76% (253 MB)
[#005] sha256:089372a94a2fd3eef070b83c06962561df759a3a900b05d14947487571caedfe - 0.0% (1.3 KB)
[#006] sha256:8b1f8318133d7cf4a065d785ef1685d465309bbf2b0ee4f30460d74c5e7cbf36 - 0.0% (669 Bytes)
[#007] sha256:5a44d944eda6a59bf5187ce68d5d5973c07ca64a4234c75640d78e455cae96bd - 0.0% (1.85 KB)
[#008] sha256:7fd8602c228badd84f19fa51d2d8f929c178c434e9dacba5966c52e95d0fe316 - 39.6% (194 MB)
[#009] sha256:4f4fb700ef54461cfa02571ae0db9a0dc1e0cdb5577484a6d75e68dc38e8acc1 - 0.0% (32 Bytes)
# debian.sh --arch 'arm64' out/ 'bookworm' '@1768176000'
2026-01-13 03:08:50 UTC (buildkit.dockerfile.v0)ENV PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
2026-01-13 03:08:50 UTC (buildkit.dockerfile.v0)RUN /bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends ca-certificates netbase tzdata ; rm -rf /var/lib/apt/lists/* # buildkit
2026-01-13 03:08:50 UTC (buildkit.dockerfile.v0)ENV PYTHON_VERSION=3.14.2
2026-01-13 03:08:50 UTC (buildkit.dockerfile.v0)ENV PYTHON_SHA256=ce543ab854bc256b61b71e9b27f831ffd1bfd60a479d639f8be7f9757cf573e9
2026-01-13 03:22:29 UTC (buildkit.dockerfile.v0)RUN /bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends dpkg-dev gcc gnupg libbluetooth-dev libbz2-dev libc6-dev libdb-dev libffi-dev libgdbm-dev liblzma-dev libncursesw5-dev libreadline-dev libsqlite3-dev libssl-dev libzstd-dev make tk-dev uuid-dev wget xz-utils zlib1g-dev ; wget -O python.tar.xz "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz"; echo "$PYTHON_SHA256 *python.tar.xz" | sha256sum -c -; mkdir -p /usr/src/python; tar --extract --directory /usr/src/python --strip-components=1 --file python.tar.xz; rm python.tar.xz; cd /usr/src/python; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; ./configure --build="$gnuArch" --enable-loadable-sqlite-extensions --enable-optimizations --enable-option-checking=fatal --enable-shared $(test "${gnuArch%%-*}" != 'riscv64' && echo '--with-lto') --with-ensurepip ; nproc="$(nproc)"; EXTRA_CFLAGS="$(dpkg-buildflags --get CFLAGS)"; LDFLAGS="$(dpkg-buildflags --get LDFLAGS)"; LDFLAGS="${LDFLAGS:--Wl},--strip-all"; arch="$(dpkg --print-architecture)"; arch="${arch##*-}"; case "$arch" in amd64|arm64) EXTRA_CFLAGS="${EXTRA_CFLAGS:-} -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer"; ;; i386) ;; *) EXTRA_CFLAGS="${EXTRA_CFLAGS:-} -fno-omit-frame-pointer"; ;; esac; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:-}" ; rm python; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:--Wl},-rpath='\$\$ORIGIN/../lib'" python ; make install; cd /; rm -rf /usr/src/python; find /usr/local -depth \( \( -type d -a \( -name test -o -name tests -o -name idle_test \) \) -o \( -type f -a \( -name '*.pyc' -o -name '*.pyo' -o -name 'libpython*.a' \) \) \) -exec rm -rf '{}' + ; ldconfig; apt-mark auto '.*' > /dev/null; apt-mark manual $savedAptMark; find /usr/local -type f -executable -not \( -name '*tkinter*' \) -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); printf "*%s\n", so }' | sort -u | xargs -rt dpkg-query --search | awk 'sub(":$", "", $1) { print $1 }' | sort -u | xargs -r apt-mark manual ; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; rm -rf /var/lib/apt/lists/*; export PYTHONDONTWRITEBYTECODE=1; python3 --version; pip3 --version # buildkit
2026-01-13 03:22:29 UTC (buildkit.dockerfile.v0)RUN /bin/sh -c set -eux; for src in idle3 pip3 pydoc3 python3 python3-config; do dst="$(echo "$src" | tr -d 3)"; [ -s "/usr/local/bin/$src" ]; [ ! -e "/usr/local/bin/$dst" ]; ln -svT "$src" "/usr/local/bin/$dst"; done # buildkit
2026-01-13 03:22:29 UTC (buildkit.dockerfile.v0)CMD ["python3"]
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)ARG WKHTMLTOPDF_VERSION=0.12.6.1-3
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)ARG WKHTMLTOPDF_DISTRO=bookworm
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)ARG NODE_VERSION=24.12.0
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)ENV NVM_DIR=/home/frappe/.nvm
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)ENV PATH=/home/frappe/.nvm/versions/node/v24.12.0/bin/:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)RUN |3 WKHTMLTOPDF_VERSION=0.12.6.1-3 WKHTMLTOPDF_DISTRO=bookworm NODE_VERSION=24.12.0 /bin/sh -c useradd -ms /bin/bash frappe && apt-get update && apt-get install --no-install-recommends -y curl git vim nginx gettext-base file libpango-1.0-0 libharfbuzz0b libpangoft2-1.0-0 libpangocairo-1.0-0 restic gpg mariadb-client less libpq-dev postgresql-client wait-for-it jq media-types && mkdir -p ${NVM_DIR} && curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash && . ${NVM_DIR}/nvm.sh && nvm install ${NODE_VERSION} && nvm use v${NODE_VERSION} && npm install -g yarn && nvm alias default v${NODE_VERSION} && rm -rf ${NVM_DIR}/.cache && echo 'export NVM_DIR="/home/frappe/.nvm"' >>/home/frappe/.bashrc && echo '[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm' >>/home/frappe/.bashrc && echo '[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion' >>/home/frappe/.bashrc && if [ "$(uname -m)" = "aarch64" ]; then export ARCH=arm64; fi && if [ "$(uname -m)" = "x86_64" ]; then export ARCH=amd64; fi && downloaded_file=wkhtmltox_${WKHTMLTOPDF_VERSION}.${WKHTMLTOPDF_DISTRO}_${ARCH}.deb && curl -sLO https://github.com/wkhtmltopdf/packaging/releases/download/$WKHTMLTOPDF_VERSION/$downloaded_file && apt-get install -y ./$downloaded_file && rm $downloaded_file && rm -rf /var/lib/apt/lists/* && rm -fr /etc/nginx/sites-enabled/default && pip3 install frappe-bench && sed -i '/user www-data/d' /etc/nginx/nginx.conf && ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log && touch /run/nginx.pid && chown -R frappe:frappe /etc/nginx/conf.d && chown -R frappe:frappe /etc/nginx/nginx.conf && chown -R frappe:frappe /var/log/nginx && chown -R frappe:frappe /var/lib/nginx && chown -R frappe:frappe /run/nginx.pid # buildkit
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)COPY resources/nginx-template.conf /templates/nginx/frappe.conf.template # buildkit
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)COPY resources/nginx-entrypoint.sh /usr/local/bin/nginx-entrypoint.sh # buildkit
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)USER frappe
2026-01-13 15:14:39 UTC (buildkit.dockerfile.v0)RUN |3 WKHTMLTOPDF_VERSION=0.12.6.1-3 WKHTMLTOPDF_DISTRO=bookworm NODE_VERSION=24.12.0 /bin/sh -c echo "echo \"Commands restricted in prodution container, Read FAQ before you proceed: https://frappe.io/ctr-faq\"" >> ~/.bashrc # buildkit
2026-01-13 15:27:28 UTC (buildkit.dockerfile.v0)COPY --chown=frappe:frappe /home/frappe/frappe-bench /home/frappe/frappe-bench # buildkit
2026-01-13 15:27:29 UTC (buildkit.dockerfile.v0)WORKDIR /home/frappe/frappe-bench
2026-01-13 15:27:29 UTC (buildkit.dockerfile.v0)VOLUME [/home/frappe/frappe-bench/sites /home/frappe/frappe-bench/sites/assets /home/frappe/frappe-bench/logs]
2026-01-13 15:27:29 UTC (buildkit.dockerfile.v0)CMD ["/home/frappe/frappe-bench/env/bin/gunicorn" "--chdir=/home/frappe/frappe-bench/sites" "--bind=0.0.0.0:8000" "--threads=4" "--workers=2" "--worker-class=gthread" "--worker-tmp-dir=/dev/shm" "--timeout=120" "--preload" "frappe.app:application"]
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.