Apostolos Fanakis
5 years ago
6 changed files with 183 additions and 9 deletions
@ -0,0 +1,111 @@ |
|||||
|
FROM alpine:3.10 |
||||
|
|
||||
|
LABEL maintainer="NGINX Docker Maintainers <docker-maint@nginx.com>" |
||||
|
|
||||
|
ENV NGINX_VERSION 1.17.9 |
||||
|
ENV NJS_VERSION 0.3.9 |
||||
|
ENV PKG_RELEASE 1 |
||||
|
|
||||
|
RUN set -x \ |
||||
|
# create nginx user/group first, to be consistent throughout docker variants |
||||
|
&& addgroup -g 101 -S nginx \ |
||||
|
&& adduser -S -D -H -u 101 -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx \ |
||||
|
&& 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} \ |
||||
|
" \ |
||||
|
&& case "$apkArch" in \ |
||||
|
x86_64) \ |
||||
|
# arches officially built by upstream |
||||
|
set -x \ |
||||
|
&& KEY_SHA512="e7fa8303923d9b95db37a77ad46c68fd4755ff935d0a534d26eba83de193c76166c68bfe7f65471bf8881004ef4aa6df3e34689c305662750c0172fca5d8552a *stdin" \ |
||||
|
&& apk add --no-cache --virtual .cert-deps \ |
||||
|
openssl \ |
||||
|
&& wget -O /tmp/nginx_signing.rsa.pub https://nginx.org/keys/nginx_signing.rsa.pub \ |
||||
|
&& if [ "$(openssl rsa -pubin -in /tmp/nginx_signing.rsa.pub -text -noout | openssl sha512 -r)" = "$KEY_SHA512" ]; then \ |
||||
|
echo "key verification succeeded!"; \ |
||||
|
mv /tmp/nginx_signing.rsa.pub /etc/apk/keys/; \ |
||||
|
else \ |
||||
|
echo "key verification failed!"; \ |
||||
|
exit 1; \ |
||||
|
fi \ |
||||
|
&& apk del .cert-deps \ |
||||
|
&& apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages \ |
||||
|
;; \ |
||||
|
*) \ |
||||
|
# we're on an architecture upstream doesn't officially build for |
||||
|
# let's build binaries from the published packaging sources |
||||
|
set -x \ |
||||
|
&& tempDir="$(mktemp -d)" \ |
||||
|
&& chown nobody:nobody $tempDir \ |
||||
|
&& apk add --no-cache --virtual .build-deps \ |
||||
|
gcc \ |
||||
|
libc-dev \ |
||||
|
make \ |
||||
|
openssl-dev \ |
||||
|
pcre-dev \ |
||||
|
zlib-dev \ |
||||
|
linux-headers \ |
||||
|
libxslt-dev \ |
||||
|
gd-dev \ |
||||
|
geoip-dev \ |
||||
|
perl-dev \ |
||||
|
libedit-dev \ |
||||
|
mercurial \ |
||||
|
bash \ |
||||
|
alpine-sdk \ |
||||
|
findutils \ |
||||
|
&& su nobody -s /bin/sh -c " \ |
||||
|
export HOME=${tempDir} \ |
||||
|
&& cd ${tempDir} \ |
||||
|
&& hg clone https://hg.nginx.org/pkg-oss \ |
||||
|
&& cd pkg-oss \ |
||||
|
&& hg up ${NGINX_VERSION}-${PKG_RELEASE} \ |
||||
|
&& cd alpine \ |
||||
|
&& make all \ |
||||
|
&& 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 .build-deps \ |
||||
|
&& apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages \ |
||||
|
;; \ |
||||
|
esac \ |
||||
|
# if we have leftovers from building, let's purge them (including extra, unnecessary build deps) |
||||
|
&& if [ -n "$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 \ |
||||
|
# Bring in gettext so we can get `envsubst`, then throw |
||||
|
# the rest away. To do this, we need to install `gettext` |
||||
|
# then move `envsubst` out of the way so `gettext` can |
||||
|
# be deleted completely, then move `envsubst` back. |
||||
|
&& 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 .gettext \ |
||||
|
&& mv /tmp/envsubst /usr/local/bin/ \ |
||||
|
# Bring in tzdata so users could set the timezones through the environment |
||||
|
# variables |
||||
|
&& apk add --no-cache tzdata \ |
||||
|
# forward request and error logs to docker log collector |
||||
|
&& ln -sf /dev/stdout /var/log/nginx/access.log \ |
||||
|
&& ln -sf /dev/stderr /var/log/nginx/error.log |
||||
|
|
||||
|
COPY default.conf /etc/nginx/conf.d/ |
||||
|
EXPOSE 8000 |
||||
|
|
||||
|
STOPSIGNAL SIGTERM |
||||
|
|
||||
|
CMD ["nginx", "-g", "daemon off;"] |
@ -0,0 +1,45 @@ |
|||||
|
server { |
||||
|
listen 8000; |
||||
|
server_name localhost; |
||||
|
|
||||
|
#charset koi8-r; |
||||
|
#access_log /var/log/nginx/host.access.log main; |
||||
|
|
||||
|
location / { |
||||
|
root /usr/share/nginx/html; |
||||
|
index index.html index.htm; |
||||
|
} |
||||
|
|
||||
|
#error_page 404 /404.html; |
||||
|
|
||||
|
# redirect server error pages to the static page /50x.html |
||||
|
# |
||||
|
error_page 500 502 503 504 /50x.html; |
||||
|
location = /50x.html { |
||||
|
root /usr/share/nginx/html; |
||||
|
} |
||||
|
|
||||
|
# proxy the PHP scripts to Apache listening on 127.0.0.1:80 |
||||
|
# |
||||
|
#location ~ \.php$ { |
||||
|
# proxy_pass http://127.0.0.1; |
||||
|
#} |
||||
|
|
||||
|
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 |
||||
|
# |
||||
|
#location ~ \.php$ { |
||||
|
# root html; |
||||
|
# fastcgi_pass 127.0.0.1:9000; |
||||
|
# fastcgi_index index.php; |
||||
|
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; |
||||
|
# include fastcgi_params; |
||||
|
#} |
||||
|
|
||||
|
# deny access to .htaccess files, if Apache's document root |
||||
|
# concurs with nginx's one |
||||
|
# |
||||
|
#location ~ /\.ht { |
||||
|
# deny all; |
||||
|
#} |
||||
|
} |
||||
|
|
@ -0,0 +1,4 @@ |
|||||
|
VIRTUAL_HOST=guide.apella.tk |
||||
|
VIRTUAL_PORT=8000 |
||||
|
LETSENCRYPT_HOST=guide.apella.tk |
||||
|
LETSENCRYPT_EMAIL=apotwohd@gmail.com |
@ -0,0 +1,10 @@ |
|||||
|
build: |
||||
|
@docker-compose -p apella-guide build; |
||||
|
run: |
||||
|
@docker-compose -p apella-guide up -d |
||||
|
stop: |
||||
|
@docker-compose -p apella-guide down |
||||
|
clean-data: |
||||
|
@docker-compose -p apella-guide down -v |
||||
|
clean-images: |
||||
|
@docker rmi `docker images -q -f "dangling=true"` |
Loading…
Reference in new issue