|
FROM ghcr.io/huggingface/text-embeddings-inference:cpu-1.2 AS base |
|
|
|
|
|
|
|
|
|
ENV NGINX_VERSION 1.26.0 |
|
ENV NJS_VERSION 0.8.4 |
|
ENV NJS_RELEASE 1~bookworm |
|
ENV PKG_RELEASE 1~bookworm |
|
|
|
ARG UID=101 |
|
ARG GID=101 |
|
|
|
RUN set -x \ |
|
|
|
&& groupadd --system --gid $GID nginx || true \ |
|
&& useradd --system --gid nginx --no-create-home --home /nonexistent --comment "nginx user" --shell /bin/false --uid $UID nginx || true \ |
|
&& apt-get update \ |
|
&& apt-get install --no-install-recommends --no-install-suggests -y gnupg1 ca-certificates \ |
|
&& \ |
|
NGINX_GPGKEY=573BFD6B3D8FBC641079A6ABABF5BD827BD9BF62; \ |
|
NGINX_GPGKEY_PATH=/etc/apt/keyrings/nginx-archive-keyring.gpg; \ |
|
export GNUPGHOME="$(mktemp -d)"; \ |
|
found=''; \ |
|
for server in \ |
|
hkp://keyserver.ubuntu.com:80 \ |
|
pgp.mit.edu \ |
|
; do \ |
|
echo "Fetching GPG key $NGINX_GPGKEY from $server"; \ |
|
gpg1 --keyserver "$server" --keyserver-options timeout=10 --recv-keys "$NGINX_GPGKEY" && found=yes && break; \ |
|
done; \ |
|
test -z "$found" && echo >&2 "error: failed to fetch GPG key $NGINX_GPGKEY" && exit 1; \ |
|
gpg1 --export "$NGINX_GPGKEY" > "$NGINX_GPGKEY_PATH" ; \ |
|
rm -rf "$GNUPGHOME"; \ |
|
apt-get remove --purge --auto-remove -y gnupg1 && rm -rf /var/lib/apt/lists/* \ |
|
&& dpkgArch="$(dpkg --print-architecture)" \ |
|
&& nginxPackages=" \ |
|
nginx=${NGINX_VERSION}-${PKG_RELEASE} \ |
|
nginx-module-xslt=${NGINX_VERSION}-${PKG_RELEASE} \ |
|
nginx-module-geoip=${NGINX_VERSION}-${PKG_RELEASE} \ |
|
nginx-module-image-filter=${NGINX_VERSION}-${PKG_RELEASE} \ |
|
nginx-module-njs=${NGINX_VERSION}+${NJS_VERSION}-${NJS_RELEASE} \ |
|
" \ |
|
&& case "$dpkgArch" in \ |
|
amd64|arm64) \ |
|
|
|
echo "deb [signed-by=$NGINX_GPGKEY_PATH] https://nginx.org/packages/debian/ bookworm nginx" >> /etc/apt/sources.list.d/nginx.list \ |
|
&& apt-get update \ |
|
;; \ |
|
*) \ |
|
|
|
|
|
echo "deb-src [signed-by=$NGINX_GPGKEY_PATH] https://nginx.org/packages/debian/ bookworm nginx" >> /etc/apt/sources.list.d/nginx.list \ |
|
\ |
|
|
|
&& tempDir="$(mktemp -d)" \ |
|
&& chmod 777 "$tempDir" \ |
|
|
|
\ |
|
|
|
&& savedAptMark="$(apt-mark showmanual)" \ |
|
\ |
|
|
|
&& apt-get update \ |
|
&& apt-get build-dep -y $nginxPackages \ |
|
&& ( \ |
|
cd "$tempDir" \ |
|
&& DEB_BUILD_OPTIONS="nocheck parallel=$(nproc)" \ |
|
apt-get source --compile $nginxPackages \ |
|
) \ |
|
|
|
\ |
|
|
|
|
|
&& apt-mark showmanual | xargs apt-mark auto > /dev/null \ |
|
&& { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; } \ |
|
\ |
|
|
|
&& ls -lAFh "$tempDir" \ |
|
&& ( cd "$tempDir" && dpkg-scanpackages . > Packages ) \ |
|
&& grep '^Package: ' "$tempDir/Packages" \ |
|
&& echo "deb [ trusted=yes ] file://$tempDir ./" > /etc/apt/sources.list.d/temp.list \ |
|
|
|
|
|
|
|
|
|
&& apt-get -o Acquire::GzipIndexes=false update \ |
|
;; \ |
|
esac \ |
|
\ |
|
&& apt-get install --no-install-recommends --no-install-suggests -y \ |
|
$nginxPackages \ |
|
gettext-base \ |
|
curl \ |
|
&& apt-get remove --purge --auto-remove -y && rm -rf /var/lib/apt/lists/* /etc/apt/sources.list.d/nginx.list \ |
|
\ |
|
|
|
&& if [ -n "$tempDir" ]; then \ |
|
apt-get purge -y --auto-remove \ |
|
&& rm -rf "$tempDir" /etc/apt/sources.list.d/temp.list; \ |
|
fi \ |
|
|
|
&& ln -sf /dev/stdout /var/log/nginx/access.log \ |
|
&& ln -sf /dev/stderr /var/log/nginx/error.log \ |
|
|
|
&& mkdir /docker-entrypoint.d |
|
|
|
|
|
RUN 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 |
|
|
|
COPY docker-entrypoint.sh / |
|
COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d |
|
COPY 15-local-resolvers.envsh /docker-entrypoint.d |
|
COPY 20-envsubst-on-templates.sh /docker-entrypoint.d |
|
COPY 30-tune-worker-processes.sh /docker-entrypoint.d |
|
ENTRYPOINT ["/docker-entrypoint.sh"] |
|
|
|
EXPOSE 8080 |
|
|
|
STOPSIGNAL SIGQUIT |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
FROM base |
|
|
|
RUN mkdir -p /data |
|
RUN chown -R nginx /data |
|
RUN chmod -R 777 /data |
|
|
|
RUN mkdir -p /home/nginx/.cache/huggingface |
|
RUN chown -R nginx /home/nginx/.cache/huggingface |
|
RUN chmod -R 777 /home/nginx/ |
|
|
|
|
|
USER nginx |
|
|
|
|
|
ENV HOME=/home/nginx \ |
|
PATH=/home/nginx/.local/bin:$PATH |
|
|
|
|
|
|
|
|
|
WORKDIR $HOME/app |
|
|
|
COPY ./index.html /usr/share/nginx/html |
|
|
|
COPY --chown=nginx ./start.sh $HOME/app/start.sh |
|
RUN chmod +x $HOME/app/start.sh |
|
|
|
RUN ls -alh . |
|
|
|
ENTRYPOINT ["./start.sh", "&"] |
|
|