镜像构建历史
# 2024-10-24 10:28:23 0.00B 声明容器运行时监听的端口
EXPOSE map[8000/tcp:{}]
# 2024-10-24 10:28:23 0.00B 指定检查容器健康状态的命令
HEALTHCHECK &{["CMD-SHELL" "curl -sf -o /dev/null http://localhost:8000 || exit 1"] "30s" "5s" "10s" "0s" '\x03'}
# 2024-10-24 10:28:23 91.71MB 复制新文件或目录到容器中
COPY /srv/build/prod /usr/share/nginx/html # buildkit
# 2024-10-24 08:20:19 1.10KB 执行命令并创建新的镜像层
RUN /bin/sh -c sed -i -e 's/listen 8080;/listen 8000;/g' -e '/listen 8000;/a\' -e ' listen [::]:8000;' /etc/nginx/conf.d/default.conf # buildkit
# 2024-10-24 08:20:19 0.00B 添加元数据标签
LABEL maintainer=Martijn Pepping <martijn.pepping@automiq.nl> org.label-schema.schema-version=1.0 org.label-schema.vcs-ref=github.com/mpepping/docker-cyberchef org.label-schema.name=mpepping/cyberchef org.label-schema.description=CyberChef org.label-schema.url=https://github.com/mpepping/docker-cyberchef org.label-schema.vcs-url=https://github.com/mpepping/docker-cyberchef org.label-schema.vendor=Martijn Pepping org.label-schema.docker.cmd=docker run -it mpepping/cyberchef:latest
# 2024-10-21 09:24:28 0.00B 指定运行容器时使用的用户
USER 101
# 2024-10-21 09:24:28 37.69MB 执行命令并创建新的镜像层
RUN |2 UID=101 GID=101 /bin/sh -c set -x && apkArch="$(cat /etc/apk/arch)" && nginxPackages=" nginx=${NGINX_VERSION}-r${PKG_RELEASE} nginx-module-xslt=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-geoip=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-image-filter=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-njs=${NGINX_VERSION}.${NJS_VERSION}-r${NJS_RELEASE} " && apk add --no-cache --virtual .checksum-deps openssl && case "$apkArch" in x86_64|aarch64) apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages ;; *) set -x && tempDir="$(mktemp -d)" && chown nobody:nobody $tempDir && apk add --no-cache --virtual .build-deps gcc libc-dev make openssl-dev pcre2-dev zlib-dev linux-headers libxslt-dev gd-dev geoip-dev libedit-dev bash alpine-sdk findutils curl && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -L -O https://github.com/nginx/pkg-oss/archive/${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && PKGOSSCHECKSUM=\"6982e2df739645fc72db5bdf994032f799718230e7016e811d9d482e5cf41814c888660ca9a68814d5e99ab571e892ada3bd43166e720cbf04c7f85b6934772c *${NGINX_VERSION}-${PKG_RELEASE}.tar.gz\" && if [ \"\$(openssl sha512 -r ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && cd pkg-oss-${NGINX_VERSION}-${PKG_RELEASE} && cd alpine && make module-geoip module-image-filter module-njs module-xslt && apk index --allow-untrusted -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz " && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ && apk del --no-network .build-deps && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages ;; esac && apk del --no-network .checksum-deps && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -f "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && apk add --no-cache curl ca-certificates # buildkit
# 2024-10-21 09:24:28 0.00B 指定运行容器时使用的用户
USER root
# 2024-10-21 09:24:28 0.00B 定义构建参数
ARG GID=101
# 2024-10-21 09:24:28 0.00B 定义构建参数
ARG UID=101
# 2024-10-21 09:24:28 0.00B 设置环境变量 NJS_RELEASE
ENV NJS_RELEASE=1
# 2024-10-21 09:24:28 0.00B 设置环境变量 NJS_VERSION
ENV NJS_VERSION=0.8.6
# 2024-10-21 08:22:40 0.00B 设置默认要执行的命令
CMD ["nginx" "-g" "daemon off;"]
# 2024-10-21 08:22:40 0.00B 指定运行容器时使用的用户
USER 101
# 2024-10-21 08:22:40 0.00B 设置停止容器时发送的系统调用信号
STOPSIGNAL SIGQUIT
# 2024-10-21 08:22:40 0.00B 声明容器运行时监听的端口
EXPOSE map[8080/tcp:{}]
# 2024-10-21 08:22:40 0.00B 配置容器启动时运行的命令
ENTRYPOINT ["/docker-entrypoint.sh"]
# 2024-10-21 08:22:40 4.62KB 复制新文件或目录到容器中
COPY 30-tune-worker-processes.sh /docker-entrypoint.d # buildkit
# 2024-10-21 08:22:40 3.01KB 复制新文件或目录到容器中
COPY 20-envsubst-on-templates.sh /docker-entrypoint.d # buildkit
# 2024-10-21 08:22:40 389.00B 复制新文件或目录到容器中
COPY 15-local-resolvers.envsh /docker-entrypoint.d # buildkit
# 2024-10-21 08:22:40 2.13KB 复制新文件或目录到容器中
COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d # buildkit
# 2024-10-21 08:22:40 1.62KB 复制新文件或目录到容器中
COPY docker-entrypoint.sh / # buildkit
# 2024-10-21 08:22:40 10.65KB 执行命令并创建新的镜像层
RUN |2 UID=101 GID=101 /bin/sh -c sed -i 's,listen 80;,listen 8080;,' /etc/nginx/conf.d/default.conf && sed -i '/user nginx;/d' /etc/nginx/nginx.conf && sed -i 's,/var/run/nginx.pid,/tmp/nginx.pid,' /etc/nginx/nginx.conf && sed -i "/^http {/a \ proxy_temp_path /tmp/proxy_temp;\n client_body_temp_path /tmp/client_temp;\n fastcgi_temp_path /tmp/fastcgi_temp;\n uwsgi_temp_path /tmp/uwsgi_temp;\n scgi_temp_path /tmp/scgi_temp;\n" /etc/nginx/nginx.conf && chown -R $UID:0 /var/cache/nginx && chmod -R g+w /var/cache/nginx && chown -R $UID:0 /etc/nginx && chmod -R g+w /etc/nginx # buildkit
# 2024-10-21 08:22:39 10.27MB 执行命令并创建新的镜像层
RUN |2 UID=101 GID=101 /bin/sh -c set -x && addgroup -g $GID -S nginx || true && adduser -S -D -H -u $UID -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx || true && apkArch="$(cat /etc/apk/arch)" && nginxPackages=" nginx=${NGINX_VERSION}-r${PKG_RELEASE} " && apk add --no-cache --virtual .checksum-deps openssl && case "$apkArch" in x86_64|aarch64) set -x && KEY_SHA512="e09fa32f0a0eab2b879ccbbc4d0e4fb9751486eedda75e35fac65802cc9faa266425edf83e261137a2f4d16281ce2c1a5f4502930fe75154723da014214f0655" && wget -O /tmp/nginx_signing.rsa.pub https://nginx.org/keys/nginx_signing.rsa.pub && if echo "$KEY_SHA512 */tmp/nginx_signing.rsa.pub" | sha512sum -c -; then echo "key verification succeeded!"; mv /tmp/nginx_signing.rsa.pub /etc/apk/keys/; else echo "key verification failed!"; exit 1; fi && apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages ;; *) set -x && tempDir="$(mktemp -d)" && chown nobody:nobody $tempDir && apk add --no-cache --virtual .build-deps gcc libc-dev make openssl-dev pcre2-dev zlib-dev linux-headers bash alpine-sdk findutils curl && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -L -O https://github.com/nginx/pkg-oss/archive/${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && PKGOSSCHECKSUM=\"6982e2df739645fc72db5bdf994032f799718230e7016e811d9d482e5cf41814c888660ca9a68814d5e99ab571e892ada3bd43166e720cbf04c7f85b6934772c *${NGINX_VERSION}-${PKG_RELEASE}.tar.gz\" && if [ \"\$(openssl sha512 -r ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && cd pkg-oss-${NGINX_VERSION}-${PKG_RELEASE} && cd alpine && make base && apk index --allow-untrusted -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz " && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ && apk del --no-network .build-deps && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages ;; esac && apk del --no-network .checksum-deps && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -f "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && apk add --no-cache --virtual .gettext gettext && mv /usr/bin/envsubst /tmp/ && runDeps="$( scanelf --needed --nobanner /tmp/envsubst | awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' | sort -u | xargs -r apk info --installed | sort -u )" && apk add --no-cache $runDeps && apk del --no-network .gettext && mv /tmp/envsubst /usr/local/bin/ && apk add --no-cache tzdata && ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log && mkdir /docker-entrypoint.d # buildkit
# 2024-10-21 08:22:39 0.00B 定义构建参数
ARG GID=101
# 2024-10-21 08:22:39 0.00B 定义构建参数
ARG UID=101
# 2024-10-21 08:22:39 0.00B 设置环境变量 DYNPKG_RELEASE
ENV DYNPKG_RELEASE=1
# 2024-10-21 08:22:39 0.00B 设置环境变量 PKG_RELEASE
ENV PKG_RELEASE=1
# 2024-10-21 08:22:39 0.00B 设置环境变量 NGINX_VERSION
ENV NGINX_VERSION=1.27.2
# 2024-10-21 08:22:39 0.00B 添加元数据标签
LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>
# 2024-09-07 06:44:11 0.00B
/bin/sh -c #(nop) CMD ["/bin/sh"]
# 2024-09-07 06:44:10 8.83MB
/bin/sh -c #(nop) ADD file:ee5bb8409915b11413f44cce4c22fed658aba4fb078a448e08dd4ac9a23581f2 in /
镜像信息
{
"Id": "sha256:840929f614db73823a3f524cb545c8a3460b8506a1a93265ff2a5d50ac295025",
"RepoTags": [
"mpepping/cyberchef:v10.19.4",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/mpepping/cyberchef:v10.19.4-linuxarm64"
],
"RepoDigests": [
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/mpepping/cyberchef@sha256:16914aacd556130357d257345ca466bc7897c86b975b83c9adc8276440c9711b"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2024-10-24T02:28:23.130132926Z",
"Container": "",
"ContainerConfig": null,
"DockerVersion": "",
"Author": "",
"Config": {
"Hostname": "",
"Domainname": "",
"User": "101",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"ExposedPorts": {
"8000/tcp": {},
"8080/tcp": {}
},
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
"NGINX_VERSION=1.27.2",
"PKG_RELEASE=1",
"DYNPKG_RELEASE=1",
"NJS_VERSION=0.8.6",
"NJS_RELEASE=1"
],
"Cmd": [
"nginx",
"-g",
"daemon off;"
],
"Healthcheck": {
"Test": [
"CMD-SHELL",
"curl -sf -o /dev/null http://localhost:8000 || exit 1"
],
"Interval": 30000000000,
"Timeout": 5000000000,
"StartPeriod": 10000000000,
"Retries": 3
},
"ArgsEscaped": true,
"Image": "",
"Volumes": null,
"WorkingDir": "",
"Entrypoint": [
"/docker-entrypoint.sh"
],
"OnBuild": null,
"Labels": {
"maintainer": "Martijn Pepping \u003cmartijn.pepping@automiq.nl\u003e",
"org.label-schema.description": "CyberChef",
"org.label-schema.docker.cmd": "docker run -it mpepping/cyberchef:latest",
"org.label-schema.name": "mpepping/cyberchef",
"org.label-schema.schema-version": "1.0",
"org.label-schema.url": "https://github.com/mpepping/docker-cyberchef",
"org.label-schema.vcs-ref": "github.com/mpepping/docker-cyberchef",
"org.label-schema.vcs-url": "https://github.com/mpepping/docker-cyberchef",
"org.label-schema.vendor": "Martijn Pepping",
"org.opencontainers.image.created": "2024-10-21T01:23:59.299Z",
"org.opencontainers.image.description": "Unprivileged NGINX Dockerfiles",
"org.opencontainers.image.licenses": "Apache-2.0",
"org.opencontainers.image.revision": "338d5c7e6a0f1c1294c3127e1481ea0739a23d87",
"org.opencontainers.image.source": "https://github.com/nginxinc/docker-nginx-unprivileged",
"org.opencontainers.image.title": "docker-nginx-unprivileged",
"org.opencontainers.image.url": "https://github.com/nginxinc/docker-nginx-unprivileged",
"org.opencontainers.image.version": "1.27.2-alpine"
},
"StopSignal": "SIGQUIT"
},
"Architecture": "arm64",
"Os": "linux",
"Size": 148520807,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/3df256cceb5f2745dbcf419178d827c00e2a1da6c08eaa248ab8ce3cdc093301/diff:/var/lib/docker/overlay2/464674d044ca3a9e9379f179420673e2d0e23b075269539cf53ed7c189f06d71/diff:/var/lib/docker/overlay2/3045c5a1e5662ffff1421a33b16c77ade4dbb031dbe009eb9221dba738d8cdbf/diff:/var/lib/docker/overlay2/d85c5968b87c23ed7575f45f06f3378a4f0bf685663d89a6e8caef52f4a1efbc/diff:/var/lib/docker/overlay2/14e6cbe85ee9db2816584a5449a022079bb1d5de1afe48d77b9ecdb07b99bdb8/diff:/var/lib/docker/overlay2/01a82066b6c71aedb2d7f16e3f24dc70fb2d0033a80616502794950a284c2ef2/diff:/var/lib/docker/overlay2/1afcd9cf283f509215368edac9f28811c34b18ce27f025673087161abdc242b2/diff:/var/lib/docker/overlay2/5d7cd6afd878d5170226d5b2b0eadcef4358ffe967e70c181d8362585cf859d4/diff:/var/lib/docker/overlay2/378e514b1468489db330ced820a23814bed51a9edd2f121ae6fbeb02136fe906/diff:/var/lib/docker/overlay2/73cf4f24ddd05900d4087c36378903fd222c1490c480c1dcfe48da4f1052919f/diff",
"MergedDir": "/var/lib/docker/overlay2/2567e8570f3c79a6e0d5db416edd5b7ba56dc4b2899b915789c64eea24cf5ac2/merged",
"UpperDir": "/var/lib/docker/overlay2/2567e8570f3c79a6e0d5db416edd5b7ba56dc4b2899b915789c64eea24cf5ac2/diff",
"WorkDir": "/var/lib/docker/overlay2/2567e8570f3c79a6e0d5db416edd5b7ba56dc4b2899b915789c64eea24cf5ac2/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:16113d51b7181f20135f51e8ffbaead20a7671cd783017601f198748ce8a8ebf",
"sha256:23ded71986ea8845b299c58e3e1696f3b48911c22a77f6c53d3dd2507f8042cd",
"sha256:cd3847843453a4fe9af730c99539a9928f1c2ae4860319ecc4cb983b93c9ca55",
"sha256:0753eef63e0a49b10f8c3b4c7ab73dce3eb19a337dd05d9e72d40f8fe3adc916",
"sha256:7193fe9a7bbf06e91637909b4a9a0ab6cd5f166aed09f6db71ce1d615cb874d9",
"sha256:6d2b3e8d5a54f9d2371b5bee6c1db2c0c8d2dd99035633da589a4c164ef0f741",
"sha256:d56c5d339754a074b1f5835f5fd53824024506a1fc0079ca812fffec66c17819",
"sha256:a01b2bb217ed3c48e745461725fca2dbd999acb9ff28988c97a0517d1fab5026",
"sha256:ea1e9ac1e930632d370fd98a880336f7f54f78eae897631a7e9abb219ccf27cb",
"sha256:deea8fe03a27e5b8eba2504759dea71109e4fbb2802e993c05a7bb7a316d9fe9",
"sha256:247136ac7367bf07b922b828a3ab178e753721e0aa63ad6b94462cc0ca95bb8a"
]
},
"Metadata": {
"LastTagTime": "2025-09-13T01:11:41.360738774+08:00"
}
}