镜像构建历史
# 2024-04-22 08:56:32 0.00B 指定运行容器时使用的用户
USER 101
# 2024-04-22 08:56:32 30.66MB 执行命令并创建新的镜像层
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${PKG_RELEASE} nginx-module-geoip=${NGINX_VERSION}-r${PKG_RELEASE} nginx-module-image-filter=${NGINX_VERSION}-r${PKG_RELEASE} nginx-module-njs=${NGINX_VERSION}.${NJS_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 libxslt-dev gd-dev geoip-dev libedit-dev bash alpine-sdk findutils && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -O https://hg.nginx.org/pkg-oss/archive/e5d85b3424bb.tar.gz && PKGOSSCHECKSUM=\"4f33347bf05e7d7dd42a52b6e7af7ec21e3ed71df05a8ec16dd1228425f04e4318d88b1340370ccb6ad02cde590fc102094ddffbb1fc86d2085295a43f02f67b *e5d85b3424bb.tar.gz\" && if [ \"\$(openssl sha512 -r e5d85b3424bb.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf e5d85b3424bb.tar.gz && cd pkg-oss-e5d85b3424bb && cd alpine && make module-geoip module-image-filter module-njs module-xslt && apk index -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 [ -f "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -n "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && if [ -n "/etc/apk/keys/nginx_signing.rsa.pub" ]; then rm -f /etc/apk/keys/nginx_signing.rsa.pub; fi && apk add --no-cache curl ca-certificates # buildkit
# 2024-04-22 08:56:32 0.00B 指定运行容器时使用的用户
USER root
# 2024-04-22 08:56:32 0.00B 定义构建参数
ARG GID=101
# 2024-04-22 08:56:32 0.00B 定义构建参数
ARG UID=101
# 2024-04-22 08:56:32 0.00B 设置环境变量 NJS_VERSION
ENV NJS_VERSION=0.8.0
# 2024-04-22 08:03:49 0.00B 设置默认要执行的命令
CMD ["nginx" "-g" "daemon off;"]
# 2024-04-22 08:03:49 0.00B 指定运行容器时使用的用户
USER 101
# 2024-04-22 08:03:49 0.00B 设置停止容器时发送的系统调用信号
STOPSIGNAL SIGQUIT
# 2024-04-22 08:03:49 0.00B 声明容器运行时监听的端口
EXPOSE map[8080/tcp:{}]
# 2024-04-22 08:03:49 0.00B 配置容器启动时运行的命令
ENTRYPOINT ["/docker-entrypoint.sh"]
# 2024-04-22 08:03:49 4.62KB 复制新文件或目录到容器中
COPY 30-tune-worker-processes.sh /docker-entrypoint.d # buildkit
# 2024-04-22 08:03:49 3.01KB 复制新文件或目录到容器中
COPY 20-envsubst-on-templates.sh /docker-entrypoint.d # buildkit
# 2024-04-22 08:03:49 336.00B 复制新文件或目录到容器中
COPY 15-local-resolvers.envsh /docker-entrypoint.d # buildkit
# 2024-04-22 08:03:49 2.13KB 复制新文件或目录到容器中
COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d # buildkit
# 2024-04-22 08:03:49 1.62KB 复制新文件或目录到容器中
COPY docker-entrypoint.sh / # buildkit
# 2024-04-22 08:03:49 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-04-22 08:03:49 9.32MB 执行命令并创建新的镜像层
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 && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -O https://hg.nginx.org/pkg-oss/archive/e5d85b3424bb.tar.gz && PKGOSSCHECKSUM=\"4f33347bf05e7d7dd42a52b6e7af7ec21e3ed71df05a8ec16dd1228425f04e4318d88b1340370ccb6ad02cde590fc102094ddffbb1fc86d2085295a43f02f67b *e5d85b3424bb.tar.gz\" && if [ \"\$(openssl sha512 -r e5d85b3424bb.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf e5d85b3424bb.tar.gz && cd pkg-oss-e5d85b3424bb && cd alpine && make base && apk index -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 [ -f "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -n "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && if [ -n "/etc/apk/keys/nginx_signing.rsa.pub" ]; then rm -f /etc/apk/keys/nginx_signing.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-04-22 08:03:49 0.00B 定义构建参数
ARG GID=101
# 2024-04-22 08:03:49 0.00B 定义构建参数
ARG UID=101
# 2024-04-22 08:03:49 0.00B 设置环境变量 PKG_RELEASE
ENV PKG_RELEASE=1
# 2024-04-22 08:03:49 0.00B 设置环境变量 NGINX_VERSION
ENV NGINX_VERSION=1.24.0
# 2024-04-22 08:03:49 0.00B 添加元数据标签
LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>
# 2024-01-27 08:30:56 0.00B
/bin/sh -c #(nop) CMD ["/bin/sh"]
# 2024-01-27 08:30:56 7.34MB
/bin/sh -c #(nop) ADD file:8729f9c0258836b640e9e789c7ab029cf4547e0596557d54dd4a4d7d8e4a785f in /
镜像信息
{
"Id": "sha256:820ecdfb9af5a6e024bed186e17263e97dc4c9087190c97a7988643d823ed43c",
"RepoTags": [
"nginxinc/nginx-unprivileged:1.24-alpine",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/nginxinc/nginx-unprivileged:1.24-alpine"
],
"RepoDigests": [
"nginxinc/nginx-unprivileged@sha256:be76a26e238d9242d1778d39fd0c5a0e4676408870ed56063d4062ba654b1e4e",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/nginxinc/nginx-unprivileged@sha256:f1285cd4a5d633576bbfdde5a1f5ca6644e45ffa93a21100b2921d2ca59e7789"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2024-04-22T00:56:32.119525438Z",
"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.24.0",
"PKG_RELEASE=1",
"NJS_VERSION=0.8.0"
],
"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": "2024-04-22T00:56:15.282Z",
"org.opencontainers.image.description": "Unprivileged NGINX Dockerfiles",
"org.opencontainers.image.licenses": "Apache-2.0",
"org.opencontainers.image.revision": "b3b9e1cb419c5a44283efb539de51c6ec5d1f242",
"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.24.0-alpine"
},
"StopSignal": "SIGQUIT"
},
"Architecture": "amd64",
"Os": "linux",
"Size": 47343522,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/a93e9e303f16aa7294a6bb291d72c83c88ce9dbad384570fa196f44319db6fe9/diff:/var/lib/docker/overlay2/56603348b37d0569fa2f09e53d4eff5fcf08af7b5b99f97f4a43be22621f0cc4/diff:/var/lib/docker/overlay2/030cc6019e1b914c6bd4ccf72245fb92da6dc3528ddbceac29b4a07e682ee226/diff:/var/lib/docker/overlay2/35123e8f03b41d21cd769d9839b40f356fdea5f34c26bf63aca0a67cba9a1f06/diff:/var/lib/docker/overlay2/209608a5c2590158a5dde7d0f608cfea7c793515eff0ad5bf2aa9e151fdc8e59/diff:/var/lib/docker/overlay2/757ce21aa7ceb742e58ca5a62de11b24ce651125b6c3b9f804b7eafd16df3b25/diff:/var/lib/docker/overlay2/757cc4a816c13e032fc8952854fb7dc116134d1f704c078493cef7860401fced/diff:/var/lib/docker/overlay2/e012a313e6a77638510a8fafc31406f477b1e67127689d72cd3abdc24d17aed2/diff",
"MergedDir": "/var/lib/docker/overlay2/736091c08ce7d108297862e8b280a46e7983967aa2b4cada1ddc46913a61221b/merged",
"UpperDir": "/var/lib/docker/overlay2/736091c08ce7d108297862e8b280a46e7983967aa2b4cada1ddc46913a61221b/diff",
"WorkDir": "/var/lib/docker/overlay2/736091c08ce7d108297862e8b280a46e7983967aa2b4cada1ddc46913a61221b/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:aedc3bda2944bb9bcb6c3d475bee8b460db9a9b0f3e0b33a6ed2fd1ae0f1d445",
"sha256:0a37618275e4670c477786cdca06dae7e53944a499e0ee63662df5c09486650b",
"sha256:9867a43a18605f24883e3ea8baea22f2a08fc5901f0cdacef382316e7ab14dab",
"sha256:867fecfaee1cfa23fe9c25f8734991c326edcfc62d3684c59461a412985ae6d6",
"sha256:90a81d673656511cc7e5967ae9c36e6c5f84d454f66e66bc3c655b04238e08c0",
"sha256:8c1c637ebaa7f86c69748c0221a46b5f4e490aa788ca8e2dd807451c4567d20d",
"sha256:4d62f18ab05c026b2cf0407011b92c2145915f9440b402fac45aaff86bd43bb7",
"sha256:f71d7d911d8325bbe684894d9ab2b54674f4c856930b784035d536c79caa34b4",
"sha256:8415f0fa34e29719ecc29ff2e53254f0f4407df8865edbe0f3541f36227bcb8d"
]
},
"Metadata": {
"LastTagTime": "2025-03-14T11:37:55.618715526+08:00"
}
}