|
| 1 | +FROM alpine:%%ALPINE_VERSION%% |
| 2 | + |
| 3 | +LABEL maintainer="NGINX Docker Maintainers < [email protected]>" |
| 4 | + |
| 5 | +ENV NGINX_VERSION %%NGINX_VERSION%% |
| 6 | +ENV PKG_RELEASE %%PKG_RELEASE%% |
| 7 | + |
| 8 | +RUN set -x \ |
| 9 | +# create nginx user/group first, to be consistent throughout docker variants |
| 10 | + && addgroup -g 101 -S nginx \ |
| 11 | + && adduser -S -D -H -u 101 -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx \ |
| 12 | + && apkArch="$(cat /etc/apk/arch)" \ |
| 13 | + && nginxPackages="%%PACKAGES%% |
| 14 | + " \ |
| 15 | +# install prerequisites for public key and pkg-oss checks |
| 16 | + && apk add --no-cache --virtual .checksum-deps \ |
| 17 | + openssl \ |
| 18 | + && case "$apkArch" in \ |
| 19 | + x86_64|aarch64) \ |
| 20 | +# arches officially built by upstream |
| 21 | + set -x \ |
| 22 | + && KEY_SHA512="e7fa8303923d9b95db37a77ad46c68fd4755ff935d0a534d26eba83de193c76166c68bfe7f65471bf8881004ef4aa6df3e34689c305662750c0172fca5d8552a *stdin" \ |
| 23 | + && wget -O /tmp/nginx_signing.rsa.pub https://nginx.org/keys/nginx_signing.rsa.pub \ |
| 24 | + && if [ "$(openssl rsa -pubin -in /tmp/nginx_signing.rsa.pub -text -noout | openssl sha512 -r)" = "$KEY_SHA512" ]; then \ |
| 25 | + echo "key verification succeeded!"; \ |
| 26 | + mv /tmp/nginx_signing.rsa.pub /etc/apk/keys/; \ |
| 27 | + else \ |
| 28 | + echo "key verification failed!"; \ |
| 29 | + exit 1; \ |
| 30 | + fi \ |
| 31 | + && apk add -X "%%PACKAGEREPO%%v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages \ |
| 32 | + ;; \ |
| 33 | + *) \ |
| 34 | +# we're on an architecture upstream doesn't officially build for |
| 35 | +# let's build binaries from the published packaging sources |
| 36 | + set -x \ |
| 37 | + && tempDir="$(mktemp -d)" \ |
| 38 | + && chown nobody:nobody $tempDir \ |
| 39 | + && apk add --no-cache --virtual .build-deps \ |
| 40 | + gcc \ |
| 41 | + libc-dev \ |
| 42 | + make \ |
| 43 | + openssl-dev \ |
| 44 | + pcre2-dev \ |
| 45 | + zlib-dev \ |
| 46 | + linux-headers \ |
| 47 | + bash \ |
| 48 | + alpine-sdk \ |
| 49 | + findutils \ |
| 50 | + && su nobody -s /bin/sh -c " \ |
| 51 | + export HOME=${tempDir} \ |
| 52 | + && cd ${tempDir} \ |
| 53 | + && curl -f -O https://hg.nginx.org/pkg-oss/archive/%%REVISION%%.tar.gz \ |
| 54 | + && PKGOSSCHECKSUM=\"%%PKGOSSCHECKSUM%% *%%REVISION%%.tar.gz\" \ |
| 55 | + && if [ \"\$(openssl sha512 -r %%REVISION%%.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then \ |
| 56 | + echo \"pkg-oss tarball checksum verification succeeded!\"; \ |
| 57 | + else \ |
| 58 | + echo \"pkg-oss tarball checksum verification failed!\"; \ |
| 59 | + exit 1; \ |
| 60 | + fi \ |
| 61 | + && tar xzvf %%REVISION%%.tar.gz \ |
| 62 | + && cd pkg-oss-%%REVISION%% \ |
| 63 | + && cd alpine \ |
| 64 | + && make base \ |
| 65 | + && apk index -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk \ |
| 66 | + && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz \ |
| 67 | + " \ |
| 68 | + && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ \ |
| 69 | + && apk del .build-deps \ |
| 70 | + && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages \ |
| 71 | + ;; \ |
| 72 | + esac \ |
| 73 | +# remove checksum deps |
| 74 | + && apk del .checksum-deps \ |
| 75 | +# if we have leftovers from building, let's purge them (including extra, unnecessary build deps) |
| 76 | + && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi \ |
| 77 | + && if [ -n "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi \ |
| 78 | + && if [ -n "/etc/apk/keys/nginx_signing.rsa.pub" ]; then rm -f /etc/apk/keys/nginx_signing.rsa.pub; fi \ |
| 79 | +# Bring in gettext so we can get `envsubst`, then throw |
| 80 | +# the rest away. To do this, we need to install `gettext` |
| 81 | +# then move `envsubst` out of the way so `gettext` can |
| 82 | +# be deleted completely, then move `envsubst` back. |
| 83 | + && apk add --no-cache --virtual .gettext gettext \ |
| 84 | + && mv /usr/bin/envsubst /tmp/ \ |
| 85 | + \ |
| 86 | + && runDeps="$( \ |
| 87 | + scanelf --needed --nobanner /tmp/envsubst \ |
| 88 | + | awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \ |
| 89 | + | sort -u \ |
| 90 | + | xargs -r apk info --installed \ |
| 91 | + | sort -u \ |
| 92 | + )" \ |
| 93 | + && apk add --no-cache $runDeps \ |
| 94 | + && apk del .gettext \ |
| 95 | + && mv /tmp/envsubst /usr/local/bin/ \ |
| 96 | +# Bring in tzdata so users could set the timezones through the environment |
| 97 | +# variables |
| 98 | + && apk add --no-cache tzdata \ |
| 99 | +# forward request and error logs to docker log collector |
| 100 | + && ln -sf /dev/stdout /var/log/nginx/access.log \ |
| 101 | + && ln -sf /dev/stderr /var/log/nginx/error.log \ |
| 102 | +# create a docker-entrypoint.d directory |
| 103 | + && mkdir /docker-entrypoint.d |
| 104 | + |
| 105 | +COPY docker-entrypoint.sh / |
| 106 | +COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d |
| 107 | +COPY 20-envsubst-on-templates.sh /docker-entrypoint.d |
| 108 | +COPY 30-tune-worker-processes.sh /docker-entrypoint.d |
| 109 | +ENTRYPOINT ["/docker-entrypoint.sh"] |
| 110 | + |
| 111 | +EXPOSE 80 |
| 112 | + |
| 113 | +STOPSIGNAL SIGQUIT |
| 114 | + |
| 115 | +CMD ["nginx", "-g", "daemon off;"] |
0 commit comments