镜像构建历史
# 2025-12-08 06:14:49 0.00B 设置默认要执行的命令
CMD ["nginx" "-g" "daemon off;"]
# 2025-12-08 06:14:49 0.00B 声明容器运行时监听的端口
EXPOSE [8080/tcp]
# 2025-12-08 06:14:49 894.00B 复制新文件或目录到容器中
COPY nginx.conf /etc/nginx/conf.d/default.conf # buildkit
# 2025-12-08 06:14:49 144.26MB 复制新文件或目录到容器中
COPY /app/dist /usr/share/nginx/html # buildkit
# 2025-12-08 06:14:49 0.00B 设置环境变量 BASE_URL
ENV BASE_URL=
# 2025-12-08 06:14:49 0.00B 定义构建参数
ARG BASE_URL
# 2025-12-08 06:14:49 0.00B 设置环境变量 VITE_VERCEL_ENV
ENV VITE_VERCEL_ENV=production
# 2025-12-04 23:19:43 0.00B 指定运行容器时使用的用户
USER 101
# 2025-12-04 23:19:43 37.53MB 执行命令并创建新的镜像层
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/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=\"517bc18954ccf4efddd51986584ca1f37966833ad342a297e1fe58fd0faf14c5a4dabcb23519dca433878a2927a95d6bea05a6749ee2fa67a33bf24cdc41b1e4 *${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
# 2025-12-04 23:19:43 0.00B 指定运行容器时使用的用户
USER root
# 2025-12-04 23:19:43 0.00B 定义构建参数
ARG GID=101
# 2025-12-04 23:19:43 0.00B 定义构建参数
ARG UID=101
# 2025-12-04 23:19:43 0.00B 设置环境变量 NJS_RELEASE
ENV NJS_RELEASE=1
# 2025-12-04 23:19:43 0.00B 设置环境变量 NJS_VERSION
ENV NJS_VERSION=0.8.10
# 2025-12-04 21:41:53 0.00B 设置默认要执行的命令
CMD ["nginx" "-g" "daemon off;"]
# 2025-12-04 21:41:53 0.00B 指定运行容器时使用的用户
USER 101
# 2025-12-04 21:41:53 0.00B 设置停止容器时发送的系统调用信号
STOPSIGNAL SIGQUIT
# 2025-12-04 21:41:53 0.00B 声明容器运行时监听的端口
EXPOSE [8080/tcp]
# 2025-12-04 21:41:53 0.00B 配置容器启动时运行的命令
ENTRYPOINT ["/docker-entrypoint.sh"]
# 2025-12-04 21:41:53 4.62KB 复制新文件或目录到容器中
COPY 30-tune-worker-processes.sh /docker-entrypoint.d # buildkit
# 2025-12-04 21:41:53 3.01KB 复制新文件或目录到容器中
COPY 20-envsubst-on-templates.sh /docker-entrypoint.d # buildkit
# 2025-12-04 21:41:53 389.00B 复制新文件或目录到容器中
COPY 15-local-resolvers.envsh /docker-entrypoint.d # buildkit
# 2025-12-04 21:41:53 2.13KB 复制新文件或目录到容器中
COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d # buildkit
# 2025-12-04 21:41:53 1.62KB 复制新文件或目录到容器中
COPY docker-entrypoint.sh / # buildkit
# 2025-12-04 21:41:53 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\)\{0\,1\}/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
# 2025-12-04 21:41:52 4.12MB 执行命令并创建新的镜像层
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/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=\"517bc18954ccf4efddd51986584ca1f37966833ad342a297e1fe58fd0faf14c5a4dabcb23519dca433878a2927a95d6bea05a6749ee2fa67a33bf24cdc41b1e4 *${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
# 2025-12-04 21:41:52 0.00B 定义构建参数
ARG GID=101
# 2025-12-04 21:41:52 0.00B 定义构建参数
ARG UID=101
# 2025-12-04 21:41:52 0.00B 设置环境变量 DYNPKG_RELEASE
ENV DYNPKG_RELEASE=1
# 2025-12-04 21:41:52 0.00B 设置环境变量 PKG_RELEASE
ENV PKG_RELEASE=1
# 2025-12-04 21:41:52 0.00B 设置环境变量 NGINX_VERSION
ENV NGINX_VERSION=1.28.0
# 2025-12-04 21:41:52 0.00B 添加元数据标签
LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>
# 2025-10-08 19:06:42 0.00B 设置默认要执行的命令
CMD ["/bin/sh"]
# 2025-10-08 19:06:42 8.17MB 复制文件或目录到容器中
ADD alpine-minirootfs-3.21.5-aarch64.tar.gz / # buildkit
镜像信息
{
"Id": "sha256:140690d7004a4754dd6768946ed73db6e2b770d4c1e92ffbf9a955f5987aff49",
"RepoTags": [
"ghcr.io/sharevb/it-tools:2025.12.7",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/sharevb/it-tools:2025.12.7-linuxarm64"
],
"RepoDigests": [
"ghcr.io/sharevb/it-tools@sha256:da4738f667288bd9ce2cd964d843231d65b5569bf0e74246a48c4e161ddc2e02",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/sharevb/it-tools@sha256:065d29c91928a43191550045462b0e471a59435fd465a02886f47b89d6b334c2"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2025-12-07T22:14:49.629441107Z",
"Container": "",
"ContainerConfig": null,
"DockerVersion": "",
"Author": "",
"Config": {
"Hostname": "",
"Domainname": "",
"User": "101",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"ExposedPorts": {
"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.28.0",
"PKG_RELEASE=1",
"DYNPKG_RELEASE=1",
"NJS_VERSION=0.8.10",
"NJS_RELEASE=1",
"VITE_VERCEL_ENV=production",
"BASE_URL="
],
"Cmd": [
"nginx",
"-g",
"daemon off;"
],
"ArgsEscaped": true,
"Image": "",
"Volumes": null,
"WorkingDir": "/",
"Entrypoint": [
"/docker-entrypoint.sh"
],
"OnBuild": null,
"Labels": {
"maintainer": "NGINX Docker Maintainers \u003cdocker-maint@nginx.com\u003e",
"org.opencontainers.image.created": "2025-12-04T15:19:13.688Z",
"org.opencontainers.image.description": "Unprivileged NGINX Dockerfiles",
"org.opencontainers.image.licenses": "Apache-2.0",
"org.opencontainers.image.revision": "74cdb36f80774b3b85badfc8ffec6d5ebdfedca8",
"org.opencontainers.image.source": "https://github.com/nginx/docker-nginx-unprivileged",
"org.opencontainers.image.title": "docker-nginx-unprivileged",
"org.opencontainers.image.url": "https://github.com/nginx/docker-nginx-unprivileged",
"org.opencontainers.image.version": "1.28.0-alpine"
},
"StopSignal": "SIGQUIT"
},
"Architecture": "arm64",
"Os": "linux",
"Size": 194107151,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/4e6fa1ac4a8395d6dbf926d0ee0a0393576b9295a81d30b4be7114b7cadd9c02/diff:/var/lib/docker/overlay2/a99bb2921996853bc6ed0bb28974b949226786875ee07202785a5b176e11cd5c/diff:/var/lib/docker/overlay2/4b9ba9a95c6567b337e56b84d6e738985e24fb085139ae8af4945208bbc078a6/diff:/var/lib/docker/overlay2/5d0c3e89defa759659fa11305fca14a8bc1ee0f4a740d4b87a4495a51ee2b763/diff:/var/lib/docker/overlay2/7766d4c89ce4252d77760a23ea91a0ab44d545c452d212cecfe17232baddf57a/diff:/var/lib/docker/overlay2/ebab5264c56469cc9d6b33e6c48ca37407e3c708a6933e777288b39bd87655da/diff:/var/lib/docker/overlay2/d8148edc5f9127be3b5a9976bdd3453e9633dfbeeffc7e9512daaa20f7816ad8/diff:/var/lib/docker/overlay2/fabb2b0d5ac635b09ff7c0038ceb9213e6fad58e8f2f2d4db7b88c9b7dd20370/diff:/var/lib/docker/overlay2/24b4c50bf4ed480831bf56d327b196608aa8dfc79a9421edfcdae2c45bdbc670/diff:/var/lib/docker/overlay2/dc40dc796ddaee04113060f6835d9497557b20297b5798bcf57f8716d0cac96c/diff",
"MergedDir": "/var/lib/docker/overlay2/1bb73a26a60cfee9a08f76b7c721485e26e1b8b7339e92dc3e288aae272f2c67/merged",
"UpperDir": "/var/lib/docker/overlay2/1bb73a26a60cfee9a08f76b7c721485e26e1b8b7339e92dc3e288aae272f2c67/diff",
"WorkDir": "/var/lib/docker/overlay2/1bb73a26a60cfee9a08f76b7c721485e26e1b8b7339e92dc3e288aae272f2c67/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:982780712fdf5e22c7ed01172785fd7059a9ec11cb375c7133dc5b06c24250ff",
"sha256:51a517b97a0bde131763e99fb3bad111fdd419ca0e5138af899747455f0c9c65",
"sha256:d95eb6592e9d4dde323a830b924d27170c5cb7fe8600aeb950de6f5110de334b",
"sha256:7bc6c84400f55d89fa05f49c25e84d5ba42a0fe0c634ca929291501573906425",
"sha256:2e5d8878c07cd414c4caf0e401330615adb1c8dbdcabaa1ae3840f53ed303875",
"sha256:36b4b6a7f514ddce40248b3ccfa7f7abf50eda0f8da00fd640ace716f3728ec9",
"sha256:9c8ec6584c2223e1bb2076796a74563ec28f409534c22b9663e1b9b9e5f9e4b3",
"sha256:4f478066603c05c71571807a04b85737e579e2c0762c680aebf206c8cd1ac2e4",
"sha256:4fbf17a22641b4a3f9c1ba5046ccca6c003a7d2d40a61eea2039df3b1ad8b437",
"sha256:290f1bb53c9309c0ec2764d5e69d9e0e57342df792dfb24958ab94ce71e5e888",
"sha256:f6e31dcc52e20bf9be9147ca6f347e7b68991d8a484a1cab6ed66f833283ce15"
]
},
"Metadata": {
"LastTagTime": "2026-02-11T07:42:39.546937873+08:00"
}
}