| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256 | 
							- FROM nginx:1.22
 
- # ensure local python is preferred over distribution python
 
- ENV PATH /usr/local/bin:$PATH
 
- # http://bugs.python.org/issue19846
 
- # > At the moment, setting "LANG=C" on a Linux system *fundamentally breaks Python 3*, and that's not OK.
 
- ENV LANG C.UTF-8
 
- # runtime dependencies
 
- RUN set -eux; \
 
- 	apt-get update; \
 
- 	apt-get install -y --no-install-recommends \
 
- 		ca-certificates \
 
- 		netbase \
 
- 		tzdata \
 
- 	; \
 
- 	rm -rf /var/lib/apt/lists/*
 
- ENV GPG_KEY A035C8C19219BA821ECEA86B64E628F8D684696D
 
- ENV PYTHON_VERSION 3.10.10
 
- RUN set -eux; \
 
- 	\
 
- 	savedAptMark="$(apt-mark showmanual)"; \
 
- 	apt-get update; \
 
- 	apt-get install -y --no-install-recommends \
 
- 		dpkg-dev \
 
- 		gcc \
 
- 		gnupg dirmngr \
 
- 		libbluetooth-dev \
 
- 		libbz2-dev \
 
- 		libc6-dev \
 
- 		libdb-dev \
 
- 		libexpat1-dev \
 
- 		libffi-dev \
 
- 		libgdbm-dev \
 
- 		liblzma-dev \
 
- 		libncursesw5-dev \
 
- 		libreadline-dev \
 
- 		libsqlite3-dev \
 
- 		libssl-dev \
 
- 		make \
 
- 		tk-dev \
 
- 		uuid-dev \
 
- 		wget \
 
- 		xz-utils \
 
- 		zlib1g-dev \
 
- 	; \
 
- 	\
 
- 	wget -O python.tar.xz "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz"; \
 
- 	wget -O python.tar.xz.asc "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz.asc"; \
 
- 	GNUPGHOME="$(mktemp -d)"; export GNUPGHOME; \
 
- 	gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$GPG_KEY"; \
 
- 	gpg --batch --verify python.tar.xz.asc python.tar.xz; \
 
- 	command -v gpgconf > /dev/null && gpgconf --kill all || :; \
 
- 	rm -rf "$GNUPGHOME" python.tar.xz.asc; \
 
- 	mkdir -p /usr/src/python; \
 
- 	tar --extract --directory /usr/src/python --strip-components=1 --file python.tar.xz; \
 
- 	rm python.tar.xz; \
 
- 	\
 
- 	cd /usr/src/python; \
 
- 	gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; \
 
- 	./configure \
 
- 		--build="$gnuArch" \
 
- 		--enable-loadable-sqlite-extensions \
 
- 		--enable-optimizations \
 
- 		--enable-option-checking=fatal \
 
- 		--enable-shared \
 
- 		--with-lto \
 
- 		--with-system-expat \
 
- 		--without-ensurepip \
 
- 	; \
 
- 	nproc="$(nproc)"; \
 
- 	EXTRA_CFLAGS="$(dpkg-buildflags --get CFLAGS)"; \
 
- 	LDFLAGS="$(dpkg-buildflags --get LDFLAGS)"; \
 
- 	LDFLAGS="${LDFLAGS:--Wl},--strip-all"; \
 
- 	make -j "$nproc" \
 
- 		"EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" \
 
- 		"LDFLAGS=${LDFLAGS:-}" \
 
- 		"PROFILE_TASK=${PROFILE_TASK:-}" \
 
- 	; \
 
- # https://github.com/docker-library/python/issues/784
 
- # prevent accidental usage of a system installed libpython of the same version
 
- 	rm python; \
 
- 	make -j "$nproc" \
 
- 		"EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" \
 
- 		"LDFLAGS=${LDFLAGS:--Wl},-rpath='\$\$ORIGIN/../lib'" \
 
- 		"PROFILE_TASK=${PROFILE_TASK:-}" \
 
- 		python \
 
- 	; \
 
- 	make install; \
 
- 	\
 
- 	cd /; \
 
- 	rm -rf /usr/src/python; \
 
- 	\
 
- 	find /usr/local -depth \
 
- 		\( \
 
- 			\( -type d -a \( -name test -o -name tests -o -name idle_test \) \) \
 
- 			-o \( -type f -a \( -name '*.pyc' -o -name '*.pyo' -o -name 'libpython*.a' \) \) \
 
- 		\) -exec rm -rf '{}' + \
 
- 	; \
 
- 	\
 
- 	ldconfig; \
 
- 	\
 
- 	apt-mark auto '.*' > /dev/null; \
 
- 	apt-mark manual $savedAptMark; \
 
- 	find /usr/local -type f -executable -not \( -name '*tkinter*' \) -exec ldd '{}' ';' \
 
- 		| awk '/=>/ { print $(NF-1) }' \
 
- 		| sort -u \
 
- 		| xargs -r dpkg-query --search \
 
- 		| cut -d: -f1 \
 
- 		| sort -u \
 
- 		| xargs -r apt-mark manual \
 
- 	; \
 
- 	rm -rf /var/lib/apt/lists/*; \
 
- 	\
 
- 	python3 --version
 
- # make some useful symlinks that are expected to exist ("/usr/local/bin/python" and friends)
 
- RUN set -eux; \
 
- 	for src in idle3 pydoc3 python3 python3-config; do \
 
- 		dst="$(echo "$src" | tr -d 3)"; \
 
- 		[ -s "/usr/local/bin/$src" ]; \
 
- 		[ ! -e "/usr/local/bin/$dst" ]; \
 
- 		ln -svT "$src" "/usr/local/bin/$dst"; \
 
- 	done
 
- # if this is called "PIP_VERSION", pip explodes with "ValueError: invalid truth value '<VERSION>'"
 
- ENV PYTHON_PIP_VERSION 22.3.1
 
- # https://github.com/docker-library/python/issues/365
 
- ENV PYTHON_SETUPTOOLS_VERSION 65.5.1
 
- # https://github.com/pypa/get-pip
 
- ENV PYTHON_GET_PIP_URL https://github.com/pypa/get-pip/raw/d5cb0afaf23b8520f1bbcfed521017b4a95f5c01/public/get-pip.py
 
- ENV PYTHON_GET_PIP_SHA256 394be00f13fa1b9aaa47e911bdb59a09c3b2986472130f30aa0bfaf7f3980637
 
- RUN set -eux; \
 
- 	\
 
- 	savedAptMark="$(apt-mark showmanual)"; \
 
- 	apt-get update; \
 
- 	apt-get install -y --no-install-recommends wget; \
 
- 	\
 
- 	wget -O get-pip.py "$PYTHON_GET_PIP_URL"; \
 
- 	echo "$PYTHON_GET_PIP_SHA256 *get-pip.py" | sha256sum -c -; \
 
- 	\
 
- 	apt-mark auto '.*' > /dev/null; \
 
- 	[ -z "$savedAptMark" ] || apt-mark manual $savedAptMark > /dev/null; \
 
- 	rm -rf /var/lib/apt/lists/*; \
 
- 	\
 
- 	export PYTHONDONTWRITEBYTECODE=1; \
 
- 	\
 
- 	python get-pip.py \
 
- 		--disable-pip-version-check \
 
- 		--no-cache-dir \
 
- 		--no-compile \
 
- 		"pip==$PYTHON_PIP_VERSION" \
 
- 		"setuptools==$PYTHON_SETUPTOOLS_VERSION" \
 
- 	; \
 
- 	rm -f get-pip.py; \
 
- 	\
 
- 	pip --version
 
- RUN groupadd --gid 1000 node \
 
-   && useradd --uid 1000 --gid node --shell /bin/bash --create-home node
 
- ENV NODE_VERSION 18.15.0
 
- RUN ARCH= && dpkgArch="$(dpkg --print-architecture)" \
 
-     && case "${dpkgArch##*-}" in \
 
-       amd64) ARCH='x64';; \
 
-       ppc64el) ARCH='ppc64le';; \
 
-       s390x) ARCH='s390x';; \
 
-       arm64) ARCH='arm64';; \
 
-       armhf) ARCH='armv7l';; \
 
-       i386) ARCH='x86';; \
 
-       *) echo "unsupported architecture"; exit 1 ;; \
 
-     esac \
 
-     && set -ex \
 
-     # libatomic1 for arm
 
-     && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr xz-utils libatomic1 --no-install-recommends \
 
-     && rm -rf /var/lib/apt/lists/* \
 
-     && for key in \
 
-       4ED778F539E3634C779C87C6D7062848A1AB005C \
 
-       141F07595B7B3FFE74309A937405533BE57C7D57 \
 
-       74F12602B6F1C4E913FAA37AD3A89613643B6201 \
 
-       DD792F5973C6DE52C432CBDAC77ABFA00DDBF2B7 \
 
-       61FC681DFB92A079F1685E77973F295594EC4689 \
 
-       8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \
 
-       C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
 
-       890C08DB8579162FEE0DF9DB8BEAB4DFCF555EF4 \
 
-       C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C \
 
-       108F52B48DB57BB0CC439B2997B01419BD92F80A \
 
-     ; do \
 
-       gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" || \
 
-       gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" ; \
 
-     done \
 
-     && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" \
 
-     && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
 
-     && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
 
-     && grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
 
-     && tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner \
 
-     && rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt \
 
-     && apt-mark auto '.*' > /dev/null \
 
-     && find /usr/local -type f -executable -exec ldd '{}' ';' \
 
-       | awk '/=>/ { print $(NF-1) }' \
 
-       | sort -u \
 
-       | xargs -r dpkg-query --search \
 
-       | cut -d: -f1 \
 
-       | sort -u \
 
-       | xargs -r apt-mark manual \
 
-     && ln -s /usr/local/bin/node /usr/local/bin/nodejs \
 
-     # smoke tests
 
-     && node --version \
 
-     && npm --version
 
- ENV YARN_VERSION 1.22.19
 
- RUN set -ex \
 
-   && savedAptMark="$(apt-mark showmanual)" \
 
-   && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr --no-install-recommends \
 
-   && rm -rf /var/lib/apt/lists/* \
 
-   && for key in \
 
-     6A010C5166006599AA17F08146C2130DFD2497F5 \
 
-   ; do \
 
-     gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" || \
 
-     gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" ; \
 
-   done \
 
-   && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
 
-   && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
 
-   && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
 
-   && mkdir -p /opt \
 
-   && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
 
-   && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
 
-   && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
 
-   && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
 
-   && apt-mark auto '.*' > /dev/null \
 
-   && { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark > /dev/null; } \
 
-   && find /usr/local -type f -executable -exec ldd '{}' ';' \
 
-     | awk '/=>/ { print $(NF-1) }' \
 
-     | sort -u \
 
-     | xargs -r dpkg-query --search \
 
-     | cut -d: -f1 \
 
-     | sort -u \
 
-     | xargs -r apt-mark manual \
 
-   # smoke test
 
-   && yarn --version
 
- RUN apt-get update && \
 
-     apt-get install -y bash curl wget vim gcc g++ python3-dev libc-dev libffi-dev
 
- RUN pip3 install gunicorn
 
- RUN npm install pm2 -g
 
- ENTRYPOINT ["/usr/local/bin/pm2-runtime", "start"]
 
 
  |