镜像构建历史
# 2026-03-05 20:49:36 0.00B 设置默认要执行的命令
CMD ["nginx" "-g" "daemon off;"]
# 2026-03-05 20:49:36 0.00B 指定检查容器健康状态的命令
HEALTHCHECK &{["CMD-SHELL" "curl -fsS http://127.0.0.1:3000/ >/dev/null || exit 1"] "30s" "5s" "10s" "0s" '\x03'}
# 2026-03-05 20:49:36 0.00B 声明容器运行时监听的端口
EXPOSE [3000/tcp]
# 2026-03-05 20:49:36 3.16MB 复制新文件或目录到容器中
COPY /app/apps/admin/build/client /usr/share/nginx/html/god-mode # buildkit
# 2026-03-05 20:46:40 546.00B 复制新文件或目录到容器中
COPY apps/admin/nginx/nginx.conf /etc/nginx/nginx.conf # buildkit
# 2026-02-05 08:07:15 48.28MB 执行命令并创建新的镜像层
RUN /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} nginx-module-acme=${NGINX_VERSION}.${ACME_VERSION}-r${PKG_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 cargo clang-libclang && 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=\"b8584eaa97130ba7743dfbb2a10f665d64cb54b864e2038d0fd298d24682fc05eb4472738430b15862dabc6f374917f1b9889117051a852d36d0a6c8bc898921 *${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 && export BUILDTARGET=\"module-geoip module-image-filter module-njs module-xslt module-acme\" && if [ \"\$(apk --print-arch)\" = \"armhf\" ]; then BUILDTARGET=\"\$( echo \$BUILDTARGET | sed 's,module-acme,,' )\"; fi && make \$BUILDTARGET && 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 && if [ "$apkArch" = "armhf" ]; then nginxPackages="$( echo $nginxPackages | sed 's,nginx-module-acme=.*,,')"; fi && 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
# 2026-02-05 08:07:15 0.00B 设置环境变量 ACME_VERSION
ENV ACME_VERSION=0.3.1
# 2026-02-05 08:07:15 0.00B 设置环境变量 NJS_RELEASE
ENV NJS_RELEASE=1
# 2026-02-05 08:07:15 0.00B 设置环境变量 NJS_VERSION
ENV NJS_VERSION=0.9.5
# 2026-02-05 07:53:29 0.00B 设置默认要执行的命令
CMD ["nginx" "-g" "daemon off;"]
# 2026-02-05 07:53:29 0.00B 设置停止容器时发送的系统调用信号
STOPSIGNAL SIGQUIT
# 2026-02-05 07:53:29 0.00B 声明容器运行时监听的端口
EXPOSE map[80/tcp:{}]
# 2026-02-05 07:53:29 0.00B 配置容器启动时运行的命令
ENTRYPOINT ["/docker-entrypoint.sh"]
# 2026-02-05 07:53:29 4.62KB 复制新文件或目录到容器中
COPY 30-tune-worker-processes.sh /docker-entrypoint.d # buildkit
# 2026-02-05 07:53:29 3.02KB 复制新文件或目录到容器中
COPY 20-envsubst-on-templates.sh /docker-entrypoint.d # buildkit
# 2026-02-05 07:53:29 389.00B 复制新文件或目录到容器中
COPY 15-local-resolvers.envsh /docker-entrypoint.d # buildkit
# 2026-02-05 07:53:29 2.12KB 复制新文件或目录到容器中
COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d # buildkit
# 2026-02-05 07:53:29 1.62KB 复制新文件或目录到容器中
COPY docker-entrypoint.sh / # buildkit
# 2026-02-05 07:53:29 4.51MB 执行命令并创建新的镜像层
RUN /bin/sh -c set -x && addgroup -g 101 -S nginx && adduser -S -D -H -u 101 -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx && 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=\"b8584eaa97130ba7743dfbb2a10f665d64cb54b864e2038d0fd298d24682fc05eb4472738430b15862dabc6f374917f1b9889117051a852d36d0a6c8bc898921 *${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 gettext-envsubst && 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
# 2026-02-05 07:53:29 0.00B 设置环境变量 DYNPKG_RELEASE
ENV DYNPKG_RELEASE=1
# 2026-02-05 07:53:29 0.00B 设置环境变量 PKG_RELEASE
ENV PKG_RELEASE=1
# 2026-02-05 07:53:29 0.00B 设置环境变量 NGINX_VERSION
ENV NGINX_VERSION=1.29.5
# 2026-02-05 07:53:29 0.00B 添加元数据标签
LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>
# 2026-01-28 09:18:09 0.00B 设置默认要执行的命令
CMD ["/bin/sh"]
# 2026-01-28 09:18:09 8.70MB 复制文件或目录到容器中
ADD alpine-minirootfs-3.23.3-aarch64.tar.gz / # buildkit
镜像信息
{
"Id": "sha256:ca0ad553340fba1d4cc8aa02c2f22c0cd47d972ea78514289817d1c1ffe40cb5",
"RepoTags": [
"makeplane/plane-admin:v1.2.3",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/makeplane/plane-admin:v1.2.3-linuxarm64"
],
"RepoDigests": [
"makeplane/plane-admin@sha256:0e84c8c5f78d64645ac8af3d4271bbea39036f878d839eb2df996c7c45b1e22a",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/makeplane/plane-admin@sha256:39e9c43df185ccfb57857a332b1e8a84be6ff11549308668c3e33421c6b2e730"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2026-03-05T12:49:36.101512621Z",
"Container": "",
"ContainerConfig": null,
"DockerVersion": "",
"Author": "",
"Config": {
"Hostname": "",
"Domainname": "",
"User": "",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"ExposedPorts": {
"3000/tcp": {},
"80/tcp": {}
},
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
"NGINX_VERSION=1.29.5",
"PKG_RELEASE=1",
"DYNPKG_RELEASE=1",
"NJS_VERSION=0.9.5",
"NJS_RELEASE=1",
"ACME_VERSION=0.3.1"
],
"Cmd": [
"nginx",
"-g",
"daemon off;"
],
"Healthcheck": {
"Test": [
"CMD-SHELL",
"curl -fsS http://127.0.0.1:3000/ \u003e/dev/null || exit 1"
],
"Interval": 30000000000,
"Timeout": 5000000000,
"StartPeriod": 10000000000,
"Retries": 3
},
"ArgsEscaped": true,
"Image": "",
"Volumes": null,
"WorkingDir": "/",
"Entrypoint": [
"/docker-entrypoint.sh"
],
"OnBuild": null,
"Labels": {
"maintainer": "NGINX Docker Maintainers \u003cdocker-maint@nginx.com\u003e"
},
"StopSignal": "SIGQUIT"
},
"Architecture": "arm64",
"Os": "linux",
"Size": 64658865,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/348d916e3cc66cf1d3805e142c73014b764bcb9e1f60fcea2879ed6993774dba/diff:/var/lib/docker/overlay2/83f176531350740e1ba8771664051c8de6b46733e82171af6af30c0c13e2a631/diff:/var/lib/docker/overlay2/1df20cec8efb555e7543ebffca7922aaf30530927da9ea48f82a1cf4bc912951/diff:/var/lib/docker/overlay2/a19f5223bbcefb92c44ad53fd549bfcc4cfc273db48d2a6e6a02c90a815ee88f/diff:/var/lib/docker/overlay2/fd254590e907f6623cf514d0f4a75d5f7be423a50357775d1e55b3e2fe791926/diff:/var/lib/docker/overlay2/921e3e47fb8f1dabf8ba505dadb808de4ced526263f9eb0a1db1370f77741af6/diff:/var/lib/docker/overlay2/b12d5c3ec85bc4d1ea90d941cb156d55e6e6b793e32ee2906aed16302ff9adc4/diff:/var/lib/docker/overlay2/31f5a0ce4844d9b39e3eb717b36a7398ca2c30cd66681b48ae913eb26b20ea5c/diff:/var/lib/docker/overlay2/ff0995ec480e8121cc73c61e085659eda4ac3590bc4315bb743e7dd2e5804ab1/diff",
"MergedDir": "/var/lib/docker/overlay2/ecbb430948084e004c89567c3bbb6e45d6cb7767f95d2a1e00ef0754c8b73fdd/merged",
"UpperDir": "/var/lib/docker/overlay2/ecbb430948084e004c89567c3bbb6e45d6cb7767f95d2a1e00ef0754c8b73fdd/diff",
"WorkDir": "/var/lib/docker/overlay2/ecbb430948084e004c89567c3bbb6e45d6cb7767f95d2a1e00ef0754c8b73fdd/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:45f3ea5848e8a25ca27718b640a21ffd8c8745d342a24e1d4ddfc8c449b0a724",
"sha256:cfbf14f957f135ecac2f5cdb4300b7da195c76c5a4fca78c607f72ac5d441b58",
"sha256:ce442f0e19c5d92e00b35bd42dd09a30f888fe20fe4f67312fbecb971dc23332",
"sha256:b55a1191629ec484f3f711c05a6c942612e3a98d52587ec1b15a540ba356b054",
"sha256:ca1e0477244ef9f19fbf1ba3e2e90adb8970d6c0ba2e5e7c3cebdccd75cc0e9a",
"sha256:e7a74677e0bc45b7dd960eaefe32a84ac5e79df7674251a62e8c22adf3d5b6af",
"sha256:a5aee8cb909c972fc4c418d1ffbfb9662d41070218c98a2f55c062bb45c9771a",
"sha256:5196ca0ce6008355f2f58276a7628e88b6cb88befd0aa71ca3ba1f2785b1342b",
"sha256:f41660f20c4a3bf14e5ebdddf6fdf5ab525d3b4c11c7f3d56509ba52113a5f30",
"sha256:69f1a438cf32caab4731240130ee37c06f9de8596275b222e6726a803fb07a22"
]
},
"Metadata": {
"LastTagTime": "2026-04-03T14:37:30.279196558+08:00"
}
}