Skip to content
This repository was archived by the owner on Jan 11, 2025. It is now read-only.

Commit 3847d75

Browse files
committedNov 25, 2020
Automated updates
1 parent 93ecc74 commit 3847d75

File tree

10 files changed

+2017
-14
lines changed

10 files changed

+2017
-14
lines changed
 

‎Dockerfile

+1-1
Original file line numberDiff line numberDiff line change
@@ -125,7 +125,7 @@ ARG VER_OPENRESTY_STREAMLUA=0.0.8
125125
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126126

127127
# https://github.com/nginx/nginx/releases
128-
ARG VER_NGINX=1.19.4
128+
ARG VER_NGINX=1.19.5
129129
ENV VER_NGINX=$VER_NGINX
130130
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131131
ENV NGX_CFLAGS=$NGX_CFLAGS

‎README.md

+6-6
Original file line numberDiff line numberDiff line change
@@ -29,12 +29,12 @@ Nginx 1.19+ with Lua support based on Alpine Linux, Amazon Linux, CentOS, Debian
2929
## Supported tags and respective `Dockerfile` links
3030

3131
<!-- START_SUPPORTED_TAGS -->
32-
- [`1`,`1.19`,`1.19.4`,`alpine`,`1-alpine`,`1.19-alpine`,`1.19.4-alpine`,`1-alpine3.12.1`,`1-alpine3.12.1`,`1.19-alpine3.12.1`,`1.19.4-alpine3.12.1`,`latest`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/alpine/3.12.1/Dockerfile)
33-
- [`amazonlinux`,`1-amazonlinux`,`1.19-amazonlinux`,`1.19.4-amazonlinux`,`1-amazonlinux2.0.20200722.0`,`1-amazonlinux2.0.20200722.0`,`1.19-amazonlinux2.0.20200722.0`,`1.19.4-amazonlinux2.0.20200722.0`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/amazonlinux/2.0.20200722.0/Dockerfile)
34-
- [`centos`,`1-centos`,`1-centos8`,`1-centos8`,`1.19-centos`,`1.19-centos8`,`1.19.4-centos`,`1.19.4-centos8`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/centos/8/Dockerfile)
35-
- [`debian`,`1-debian`,`1.19-debian`,`1-debian10.6`,`1-debian10.6`,`1.19.4-debian`,`1.19-debian10.6`,`1.19.4-debian10.6`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/debian/10.6/Dockerfile)
36-
- [`fedora`,`1-fedora`,`1-fedora33`,`1-fedora33`,`1.19-fedora`,`1.19-fedora33`,`1.19.4-fedora`,`1.19.4-fedora33`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/fedora/33/Dockerfile)
37-
- [`ubuntu`,`1-ubuntu`,`1.19-ubuntu`,`1-ubuntu20.04`,`1-ubuntu20.04`,`1.19.4-ubuntu`,`1.19-ubuntu20.04`,`1.19.4-ubuntu20.04`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/ubuntu/20.04/Dockerfile)
32+
- [`1`,`1.19`,`1.19.5`,`alpine`,`1-alpine`,`1.19-alpine`,`1.19.5-alpine`,`1-alpine3.12.1`,`1-alpine3.12.1`,`1.19-alpine3.12.1`,`1.19.5-alpine3.12.1`,`latest`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/alpine/3.12.1/Dockerfile)
33+
- [`amazonlinux`,`1-amazonlinux`,`1.19-amazonlinux`,`1.19.5-amazonlinux`,`1-amazonlinux2.0.20200722.0`,`1-amazonlinux2.0.20200722.0`,`1.19-amazonlinux2.0.20200722.0`,`1.19.5-amazonlinux2.0.20200722.0`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/amazonlinux/2.0.20200722.0/Dockerfile)
34+
- [`centos`,`1-centos`,`1-centos8`,`1-centos8`,`1.19-centos`,`1.19-centos8`,`1.19.5-centos`,`1.19.5-centos8`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/centos/8/Dockerfile)
35+
- [`debian`,`1-debian`,`1.19-debian`,`1-debian10.6`,`1-debian10.6`,`1.19.5-debian`,`1.19-debian10.6`,`1.19.5-debian10.6`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/debian/10.6/Dockerfile)
36+
- [`fedora`,`1-fedora`,`1-fedora33`,`1-fedora33`,`1.19-fedora`,`1.19-fedora33`,`1.19.5-fedora`,`1.19.5-fedora33`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/fedora/33/Dockerfile)
37+
- [`ubuntu`,`1-ubuntu`,`1.19-ubuntu`,`1-ubuntu20.04`,`1-ubuntu20.04`,`1.19.5-ubuntu`,`1.19-ubuntu20.04`,`1.19.5-ubuntu20.04`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/ubuntu/20.04/Dockerfile)
3838
<!-- END_SUPPORTED_TAGS -->
3939

4040
**Note:** The full list of supported/unsupported tags can be found on [`docs/TAGS.md`](https://github.com/fabiocicerchia/nginx-lua/blob/main/docs/TAGS.md).

‎docs/TAGS.md

+12-6
Original file line numberDiff line numberDiff line change
@@ -2,15 +2,21 @@
22

33
## Supported Tags
44

5-
- [`1-alpine`, `1`, `1.19-alpine`, `1.19`, `1.19-alpine3.12.1`, `1-alpine3.12.1`, `1.19.4-alpine3.12.1`, `1.19.4-alpine`, `1.19-4`, `alpine`, `latest`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/alpine/3.12.1/Dockerfile)
6-
- [`1-amazonlinux`, `1.19-amazonlinux`, `1.19-amazonlinux2.0.20200722.0`, `1-amazonlinux2.0.20200722.0`, `1.19.4-amazonlinux2.0.20200722.0`, `1.19.4-amazonlinux`, `amazonlinux`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/amazonlinux/2.0.20200722.0/Dockerfile)
7-
- [`1-centos`, `1.19-centos`, `1.19-centos8`, `1-centos8`, `1.19.4-centos8`, `1.19.4-centos`, `centos`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/centos/8/Dockerfile)
8-
- [`1-debian`, `1.19-debian`, `1.19-debian10.6`, `1-debian10.6`, `1.19.4-debian10.6`, `1.19.4-debian`, `debian`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/debian/10.6/Dockerfile)
9-
- [`1-fedora`, `1-fedora33`, `1.19-fedora`, `1.19-fedora33`, `1.19.4-fedora33`, `1.19.4-fedora`, `fedora`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/fedora/33/Dockerfile)
10-
- [`1-ubuntu`, `1-ubuntu20.04`, `1.19-ubuntu`, `1.19-ubuntu20.04`, `1.19.4-ubuntu20.04`, `1.19.4-ubuntu`, `ubuntu`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/ubuntu/20.04/Dockerfile)
5+
- [`1-alpine`, `1`, `1.19-alpine`, `1.19`, `1.19-alpine3.12.1`, `1-alpine3.12.1`, `1.19.5-alpine3.12.1`, `1.19.5-alpine`, `1.19-5`, `alpine`, `latest`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/alpine/3.12.1/Dockerfile)
6+
- [`1-amazonlinux`, `1.19-amazonlinux`, `1.19-amazonlinux2.0.20200722.0`, `1-amazonlinux2.0.20200722.0`, `1.19.5-amazonlinux2.0.20200722.0`, `1.19.5-amazonlinux`, `amazonlinux`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/amazonlinux/2.0.20200722.0/Dockerfile)
7+
- [`1-centos`, `1.19-centos`, `1.19-centos8`, `1-centos8`, `1.19.5-centos8`, `1.19.5-centos`, `centos`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/centos/8/Dockerfile)
8+
- [`1-debian`, `1.19-debian`, `1.19-debian10.6`, `1-debian10.6`, `1.19.5-debian10.6`, `1.19.5-debian`, `debian`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/debian/10.6/Dockerfile)
9+
- [`1-fedora`, `1-fedora33`, `1.19-fedora`, `1.19-fedora33`, `1.19.5-fedora33`, `1.19.5-fedora`, `fedora`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/fedora/33/Dockerfile)
10+
- [`1-ubuntu`, `1-ubuntu20.04`, `1.19-ubuntu`, `1.19-ubuntu20.04`, `1.19.5-ubuntu20.04`, `1.19.5-ubuntu`, `ubuntu`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.5/ubuntu/20.04/Dockerfile)
1111

1212
## Unsupported Tags
1313

14+
- [`1.19.4-ubuntu20.04`, `1.19.4-ubuntu`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/ubuntu/20.04/Dockerfile)
15+
- [`1.19.4-fedora33`, `1.19.4-fedora`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/fedora/33/Dockerfile)
16+
- [`1.19.4-debian10.6`, `1.19.4-debian`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/debian/10.6/Dockerfile)
17+
- [`1.19.4-centos8`, `1.19.4-centos`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/centos/8/Dockerfile)
18+
- [`1.19.4-amazonlinux2.0.20200722.0`, `1.19.4-amazonlinux`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/amazonlinux/2.0.20200722.0/Dockerfile)
19+
- [`1.19.4-alpine3.12.1`, `1.19.4-alpine`, `1.19-4`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.4/alpine/3.12.1/Dockerfile)
1420
- [`1-ubuntu20.10`, `1.19-ubuntu20.10`, `1.19.3-ubuntu`, `1.19.3-ubuntu20.10`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.3/ubuntu/20.10/Dockerfile)
1521
- [`1.19.3-ubuntu20.04`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.3/ubuntu/20.04/Dockerfile)
1622
- [`1.19-fedora34`, `1-fedora34`, `1.19.3-fedora`, `1.19.3-fedora34`](https://github.com/fabiocicerchia/nginx-lua/blob/main/nginx/1.19.3/fedora/34/Dockerfile)

‎nginx/1.19.5/alpine/3.12.1/Dockerfile

+344
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,344 @@
1+
# __ __
2+
# .-----.-----.|__|.-----.--.--.______| |.--.--.---.-.
3+
# | | _ || || |_ _|______| || | | _ |
4+
# |__|__|___ ||__||__|__|__.__| |__||_____|___._|
5+
# |_____|
6+
#
7+
# Copyright (c) 2020 Fabio Cicerchia. https://fabiocicerchia.it. MIT License
8+
# Repo: https://github.com/fabiocicerchia/nginx-lua
9+
10+
FROM alpine:3.12.1 AS base
11+
12+
#############################
13+
# Settings Common Variables #
14+
#############################
15+
ARG DOCKER_IMAGE=fabiocicerchia/nginx-lua
16+
ENV DOCKER_IMAGE=$DOCKER_IMAGE
17+
ARG DOCKER_IMAGE_OS=alpine
18+
ENV DOCKER_IMAGE_OS=$DOCKER_IMAGE_OS
19+
ARG DOCKER_IMAGE_TAG=3.12.1
20+
ENV DOCKER_IMAGE_TAG=$DOCKER_IMAGE_TAG
21+
22+
ARG BUILD_DATE
23+
ENV BUILD_DATE=$BUILD_DATE
24+
ARG VCS_REF
25+
ENV VCS_REF=$VCS_REF
26+
27+
ARG EXTENDED_IMAGE=1
28+
ENV EXTENDED_IMAGE=$EXTENDED_IMAGE
29+
30+
# ngx_devel_kit
31+
# https://github.com/vision5/ngx_devel_kit/releases
32+
# The NDK is now considered to be stable.
33+
ARG VER_NGX_DEVEL_KIT=0.3.1
34+
ENV VER_NGX_DEVEL_KIT=$VER_NGX_DEVEL_KIT
35+
36+
# luajit2
37+
# https://github.com/openresty/luajit2/releases
38+
ARG VER_LUAJIT=2.1-20201012-2
39+
ENV VER_LUAJIT=$VER_LUAJIT
40+
ARG LUAJIT_LIB=/usr/local/lib
41+
ENV LUAJIT_LIB=$LUAJIT_LIB
42+
ARG LUAJIT_INC=/usr/local/include/luajit-2.1
43+
ENV LUAJIT_INC=$LUAJIT_INC
44+
ARG LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH
45+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH
46+
47+
# lua-nginx-module
48+
# https://github.com/openresty/lua-nginx-module/releases
49+
# Production ready.
50+
ARG VER_LUA_NGINX_MODULE=0.10.17
51+
ENV VER_LUA_NGINX_MODULE=$VER_LUA_NGINX_MODULE
52+
53+
# lua-resty-core
54+
# https://github.com/openresty/lua-resty-core/releases
55+
# This library is production ready.
56+
ARG VER_LUA_RESTY_CORE=0.1.19
57+
ENV VER_LUA_RESTY_CORE=$VER_LUA_RESTY_CORE
58+
ARG LUA_LIB_DIR=/usr/local/share/lua/5.1
59+
ENV LUA_LIB_DIR=$LUA_LIB_DIR
60+
61+
# lua-resty-lrucache
62+
# https://github.com/openresty/lua-resty-lrucache/releases
63+
# This library is considered production ready.
64+
ARG VER_LUA_RESTY_LRUCACHE=0.10
65+
ENV VER_LUA_RESTY_LRUCACHE=$VER_LUA_RESTY_LRUCACHE
66+
67+
# headers-more-nginx-module
68+
# https://github.com/openresty/headers-more-nginx-module/commits/master
69+
ARG VER_OPENRESTY_HEADERS=d6d7ebab3c0c5b32ab421ba186783d3e5d2c6a17
70+
ENV VER_OPENRESTY_HEADERS=$VER_OPENRESTY_HEADERS
71+
72+
# lua-resty-cookie
73+
# https://github.com/cloudflare/lua-resty-cookie/commits/master
74+
ARG VER_CLOUDFLARE_COOKIE=303e32e512defced053a6484bc0745cf9dc0d39e
75+
ENV VER_CLOUDFLARE_COOKIE=$VER_CLOUDFLARE_COOKIE
76+
77+
# lua-resty-dns
78+
# https://github.com/openresty/lua-resty-dns/releases
79+
ARG VER_OPENRESTY_DNS=0.21
80+
ENV VER_OPENRESTY_DNS=$VER_OPENRESTY_DNS
81+
82+
# lua-resty-memcached
83+
# https://github.com/openresty/lua-resty-memcached/releases
84+
ARG VER_OPENRESTY_MEMCACHED=0.15
85+
ENV VER_OPENRESTY_MEMCACHED=$VER_OPENRESTY_MEMCACHED
86+
87+
# lua-resty-mysql
88+
# https://github.com/openresty/lua-resty-mysql/releases
89+
ARG VER_OPENRESTY_MYSQL=0.22
90+
ENV VER_OPENRESTY_MYSQL=$VER_OPENRESTY_MYSQL
91+
92+
# lua-resty-redis
93+
# https://github.com/openresty/lua-resty-redis/releases
94+
ARG VER_OPENRESTY_REDIS=0.29
95+
ENV VER_OPENRESTY_REDIS=$VER_OPENRESTY_REDIS
96+
97+
# lua-resty-shell
98+
# https://github.com/openresty/lua-resty-shell/releases
99+
ARG VER_OPENRESTY_SHELL=0.03
100+
ENV VER_OPENRESTY_SHELL=$VER_OPENRESTY_SHELL
101+
102+
# lua-resty-upstream-healthcheck
103+
# https://github.com/openresty/lua-resty-upstream-healthcheck/releases
104+
ARG VER_OPENRESTY_HEALTHCHECK=0.06
105+
ENV VER_OPENRESTY_HEALTHCHECK=$VER_OPENRESTY_HEALTHCHECK
106+
107+
# lua-resty-websocket
108+
# https://github.com/openresty/lua-resty-websocket/releases
109+
ARG VER_OPENRESTY_WEBSOCKET=0.07
110+
ENV VER_OPENRESTY_WEBSOCKET=$VER_OPENRESTY_WEBSOCKET
111+
112+
# lua-upstream-nginx-module
113+
# https://github.com/openresty/lua-upstream-nginx-module/releases
114+
ARG VER_LUA_UPSTREAM=0.07
115+
ENV VER_LUA_UPSTREAM=$VER_LUA_UPSTREAM
116+
117+
# nginx-lua-prometheus
118+
# https://github.com/knyar/nginx-lua-prometheus/releases
119+
ARG VER_PROMETHEUS=0.20200523
120+
ENV VER_PROMETHEUS=$VER_PROMETHEUS
121+
122+
# stream-lua-nginx-module
123+
# https://github.com/openresty/stream-lua-nginx-module/releases
124+
ARG VER_OPENRESTY_STREAMLUA=0.0.8
125+
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126+
127+
# https://github.com/nginx/nginx/releases
128+
ARG VER_NGINX=1.19.5
129+
ENV VER_NGINX=$VER_NGINX
130+
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131+
ENV NGX_CFLAGS=$NGX_CFLAGS
132+
ARG NGX_LDOPT="-Wl,-rpath,/usr/local/lib -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie"
133+
ENV NGX_LDOPT=$NGX_LDOPT
134+
ARG NGINX_BUILD_CONFIG="\
135+
--prefix=/etc/nginx \
136+
--sbin-path=/usr/sbin/nginx \
137+
--modules-path=/usr/lib/nginx/modules \
138+
--conf-path=/etc/nginx/nginx.conf \
139+
--error-log-path=/var/log/nginx/error.log \
140+
--http-log-path=/var/log/nginx/access.log \
141+
--pid-path=/var/run/nginx.pid \
142+
--lock-path=/var/run/nginx.lock \
143+
--http-client-body-temp-path=/var/cache/nginx/client_temp \
144+
--http-proxy-temp-path=/var/cache/nginx/proxy_temp \
145+
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
146+
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
147+
--http-scgi-temp-path=/var/cache/nginx/scgi_temp \
148+
--with-perl_modules_path=/usr/lib/perl5/vendor_perl \
149+
--user=nginx \
150+
--group=nginx \
151+
--with-compat \
152+
--with-file-aio \
153+
--with-threads \
154+
--with-http_addition_module \
155+
--with-http_auth_request_module \
156+
--with-http_dav_module \
157+
--with-http_flv_module \
158+
--with-http_gunzip_module \
159+
--with-http_gzip_static_module \
160+
--with-http_mp4_module \
161+
--with-http_random_index_module \
162+
--with-http_realip_module \
163+
--with-http_secure_link_module \
164+
--with-http_slice_module \
165+
--with-http_ssl_module \
166+
--with-http_stub_status_module \
167+
--with-http_sub_module \
168+
--with-http_v2_module \
169+
--with-mail \
170+
--with-mail_ssl_module \
171+
--with-stream \
172+
--with-stream_realip_module \
173+
--with-stream_ssl_module \
174+
--with-stream_ssl_preread_module \
175+
--add-module=/lua-nginx-module-${VER_LUA_NGINX_MODULE} \
176+
--add-module=/ngx_devel_kit-${VER_NGX_DEVEL_KIT} \
177+
--add-module=/lua-upstream-nginx-module-${VER_LUA_UPSTREAM} \
178+
"
179+
ENV NGINX_BUILD_CONFIG=$NGINX_BUILD_CONFIG
180+
181+
ARG BUILD_DEPS="\
182+
curl \
183+
g++ \
184+
geoip-dev \
185+
gzip \
186+
make \
187+
openssl-dev \
188+
pcre-dev \
189+
tar \
190+
zlib-dev \
191+
"
192+
ENV BUILD_DEPS=$BUILD_DEPS
193+
194+
ARG NGINX_BUILD_DEPS="\
195+
# NGINX
196+
alpine-sdk \
197+
bash \
198+
findutils \
199+
gcc \
200+
gd-dev \
201+
geoip-dev \
202+
libc-dev \
203+
libedit-dev \
204+
libxslt-dev \
205+
linux-headers \
206+
make \
207+
openssl-dev \
208+
pcre-dev \
209+
perl-dev \
210+
zlib-dev \
211+
"
212+
ENV NGINX_BUILD_DEPS=$NGINX_BUILD_DEPS
213+
214+
####################################
215+
# Build Nginx with support for LUA #
216+
####################################
217+
FROM base AS builder
218+
219+
COPY tpl/Makefile Makefile
220+
221+
# TODO: NGINX_BUILD_CONFIG not updated
222+
# hadolint ignore=SC2086
223+
RUN set -eux \
224+
&& apk update \
225+
&& apk add --no-cache \
226+
$BUILD_DEPS \
227+
$NGINX_BUILD_DEPS \
228+
&& [ $EXTENDED_IMAGE -eq 1 ] && \
229+
NGINX_BUILD_CONFIG="${NGINX_BUILD_CONFIG} \
230+
--add-module=/headers-more-nginx-module-${VER_OPENRESTY_HEADERS} \
231+
--add-module=/stream-lua-nginx-module-${VER_OPENRESTY_STREAMLUA} \
232+
" \
233+
&& make -j "$(nproc)" deps \
234+
&& make -j "$(nproc)" core
235+
236+
##########################################
237+
# Combine everything with minimal layers #
238+
##########################################
239+
FROM alpine:3.12.1
240+
241+
# http://label-schema.org/rc1/
242+
LABEL maintainer="Fabio Cicerchia <info@fabiocicerchia.it>" \
243+
org.label-schema.build-date=$BUILD_DATE \
244+
org.label-schema.description="Nginx $VER_NGINX with Lua support based on $DOCKER_IMAGE_OS $DOCKER_IMAGE_TAG." \
245+
org.label-schema.docker.cmd="docker run -p 80:80 -d $DOCKER_IMAGE:$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
246+
org.label-schema.name="$DOCKER_IMAGE" \
247+
org.label-schema.schema-version="1.0" \
248+
org.label-schema.url="https://github.com/$DOCKER_IMAGE" \
249+
org.label-schema.vcs-ref=$VCS_REF \
250+
org.label-schema.vcs-url="https://github.com/$DOCKER_IMAGE" \
251+
org.label-schema.version="$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
252+
versions.extended=${EXTENDED_IMAGE} \
253+
versions.headers-more-nginx-module=${VER_OPENRESTY_HEADERS} \
254+
versions.lua-nginx-module=${VER_LUA_NGINX_MODULE} \
255+
versions.lua-resty-cookie=${VER_CLOUDFLARE_COOKIE} \
256+
versions.lua-resty-core=${VER_LUA_RESTY_CORE} \
257+
versions.lua-resty-dns=${VER_OPENRESTY_DNS} \
258+
versions.lua-resty-lrucache=${VER_LUA_RESTY_LRUCACHE} \
259+
versions.lua-resty-memcached=${VER_OPENRESTY_MEMCACHED} \
260+
versions.lua-resty-mysql=${VER_OPENRESTY_MYSQL} \
261+
versions.lua-resty-redis=${VER_OPENRESTY_REDIS} \
262+
versions.lua-resty-shell=${VER_OPENRESTY_SHELL} \
263+
versions.lua-resty-upstream-healthcheck=${VER_OPENRESTY_HEALTHCHECK} \
264+
versions.lua-resty-websocket=${VER_OPENRESTY_WEBSOCKET} \
265+
versions.lua-upstream=${VER_LUA_UPSTREAM} \
266+
versions.luajit2=${VER_LUAJIT} \
267+
versions.nginx-lua-prometheus=${VER_PROMETHEUS} \
268+
versions.nginx=${VER_NGINX} \
269+
versions.ngx_devel_kit=${VER_NGX_DEVEL_KIT} \
270+
versions.os=${DOCKER_IMAGE_TAG} \
271+
versions.stream-lua-nginx-module=${VER_OPENRESTY_STREAMLUA}
272+
273+
ARG PKG_DEPS="\
274+
geoip-dev \
275+
openssl-dev \
276+
pcre-dev \
277+
zlib-dev \
278+
"
279+
ENV PKG_DEPS=$PKG_DEPS
280+
281+
COPY --from=builder /etc/nginx /etc/nginx
282+
COPY --from=builder /usr/local/lib /usr/local/lib
283+
COPY --from=builder /usr/local/share/lua /usr/local/share/lua
284+
COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
285+
COPY --from=builder /usr/sbin/nginx-debug /usr/sbin/nginx-debug
286+
COPY --from=builder /var/cache/nginx /var/cache/nginx
287+
288+
SHELL ["/bin/ash", "-eo", "pipefail", "-c"]
289+
290+
# hadolint ignore=SC2086
291+
RUN set -eux \
292+
&& apk update \
293+
&& apk add --no-cache --virtual .pkg_deps \
294+
$PKG_DEPS \
295+
# Bring in gettext so we can get `envsubst`, then throw
296+
# the rest away. To do this, we need to install `gettext`
297+
# then move `envsubst` out of the way so `gettext` can
298+
# be deleted completely, then move `envsubst` back.
299+
&& apk add --no-cache --virtual .gettext gettext \
300+
&& mv /usr/bin/envsubst /tmp/ \
301+
&& runDeps="$( \
302+
scanelf --needed --nobanner /tmp/envsubst \
303+
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
304+
| sort -u \
305+
| xargs -r apk info --installed \
306+
| sort -u \
307+
)" \
308+
&& apk add --no-cache --virtual .run_deps $runDeps \
309+
&& apk del .gettext \
310+
&& mv /tmp/envsubst /usr/local/bin/ \
311+
# Bring in tzdata so users could set the timezones through the environment
312+
# variables
313+
&& apk add --no-cache --virtual pkg_tz tzdata \
314+
# Bring in curl and ca-certificates to make registering on DNS SD easier
315+
&& apk add --no-cache --virtual pkg_dns curl ca-certificates \
316+
# forward request and error logs to docker log collector
317+
&& mkdir -p /var/log/nginx \
318+
&& ln -sf /dev/stdout /var/log/nginx/access.log \
319+
&& ln -sf /dev/stderr /var/log/nginx/error.log \
320+
# create nginx user/group first, to be consistent throughout docker variants
321+
&& addgroup -g 101 -S nginx \
322+
&& adduser -S -D -H -u 101 -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx \
323+
&& mkdir /docker-entrypoint.d
324+
325+
COPY tpl/docker-entrypoint.sh /
326+
COPY tpl/10-listen-on-ipv6-by-default.sh /docker-entrypoint.d/
327+
COPY tpl/20-envsubst-on-templates.sh /docker-entrypoint.d/
328+
329+
# smoke test
330+
# ##############################################################################
331+
RUN envsubst -V \
332+
&& nginx -V \
333+
&& nginx -t
334+
335+
EXPOSE 80 443
336+
337+
HEALTHCHECK --interval=30s --timeout=3s CMD curl --fail http://localhost/ || exit 1
338+
339+
# Override stop signal to stop process gracefully
340+
STOPSIGNAL SIGQUIT
341+
342+
ENTRYPOINT ["/docker-entrypoint.sh"]
343+
344+
CMD ["nginx", "-g", "daemon off;"]
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,332 @@
1+
# __ __
2+
# .-----.-----.|__|.-----.--.--.______| |.--.--.---.-.
3+
# | | _ || || |_ _|______| || | | _ |
4+
# |__|__|___ ||__||__|__|__.__| |__||_____|___._|
5+
# |_____|
6+
#
7+
# Copyright (c) 2020 Fabio Cicerchia. https://fabiocicerchia.it. MIT License
8+
# Repo: https://github.com/fabiocicerchia/nginx-lua
9+
10+
FROM amazonlinux:2.0.20200722.0 AS base
11+
12+
#############################
13+
# Settings Common Variables #
14+
#############################
15+
ARG DOCKER_IMAGE=fabiocicerchia/nginx-lua
16+
ENV DOCKER_IMAGE=$DOCKER_IMAGE
17+
ARG DOCKER_IMAGE_OS=amazonlinux
18+
ENV DOCKER_IMAGE_OS=$DOCKER_IMAGE_OS
19+
ARG DOCKER_IMAGE_TAG=2.0.20200722.0
20+
ENV DOCKER_IMAGE_TAG=$DOCKER_IMAGE_TAG
21+
22+
ARG BUILD_DATE
23+
ENV BUILD_DATE=$BUILD_DATE
24+
ARG VCS_REF
25+
ENV VCS_REF=$VCS_REF
26+
27+
ARG EXTENDED_IMAGE=1
28+
ENV EXTENDED_IMAGE=$EXTENDED_IMAGE
29+
30+
# ngx_devel_kit
31+
# https://github.com/vision5/ngx_devel_kit/releases
32+
# The NDK is now considered to be stable.
33+
ARG VER_NGX_DEVEL_KIT=0.3.1
34+
ENV VER_NGX_DEVEL_KIT=$VER_NGX_DEVEL_KIT
35+
36+
# luajit2
37+
# https://github.com/openresty/luajit2/releases
38+
ARG VER_LUAJIT=2.1-20201012-2
39+
ENV VER_LUAJIT=$VER_LUAJIT
40+
ARG LUAJIT_LIB=/usr/local/lib
41+
ENV LUAJIT_LIB=$LUAJIT_LIB
42+
ARG LUAJIT_INC=/usr/local/include/luajit-2.1
43+
ENV LUAJIT_INC=$LUAJIT_INC
44+
ARG LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH
45+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH
46+
47+
# lua-nginx-module
48+
# https://github.com/openresty/lua-nginx-module/releases
49+
# Production ready.
50+
ARG VER_LUA_NGINX_MODULE=0.10.17
51+
ENV VER_LUA_NGINX_MODULE=$VER_LUA_NGINX_MODULE
52+
53+
# lua-resty-core
54+
# https://github.com/openresty/lua-resty-core/releases
55+
# This library is production ready.
56+
ARG VER_LUA_RESTY_CORE=0.1.19
57+
ENV VER_LUA_RESTY_CORE=$VER_LUA_RESTY_CORE
58+
ARG LUA_LIB_DIR=/usr/local/share/lua/5.1
59+
ENV LUA_LIB_DIR=$LUA_LIB_DIR
60+
61+
# lua-resty-lrucache
62+
# https://github.com/openresty/lua-resty-lrucache/releases
63+
# This library is considered production ready.
64+
ARG VER_LUA_RESTY_LRUCACHE=0.10
65+
ENV VER_LUA_RESTY_LRUCACHE=$VER_LUA_RESTY_LRUCACHE
66+
67+
# headers-more-nginx-module
68+
# https://github.com/openresty/headers-more-nginx-module/commits/master
69+
ARG VER_OPENRESTY_HEADERS=d6d7ebab3c0c5b32ab421ba186783d3e5d2c6a17
70+
ENV VER_OPENRESTY_HEADERS=$VER_OPENRESTY_HEADERS
71+
72+
# lua-resty-cookie
73+
# https://github.com/cloudflare/lua-resty-cookie/commits/master
74+
ARG VER_CLOUDFLARE_COOKIE=303e32e512defced053a6484bc0745cf9dc0d39e
75+
ENV VER_CLOUDFLARE_COOKIE=$VER_CLOUDFLARE_COOKIE
76+
77+
# lua-resty-dns
78+
# https://github.com/openresty/lua-resty-dns/releases
79+
ARG VER_OPENRESTY_DNS=0.21
80+
ENV VER_OPENRESTY_DNS=$VER_OPENRESTY_DNS
81+
82+
# lua-resty-memcached
83+
# https://github.com/openresty/lua-resty-memcached/releases
84+
ARG VER_OPENRESTY_MEMCACHED=0.15
85+
ENV VER_OPENRESTY_MEMCACHED=$VER_OPENRESTY_MEMCACHED
86+
87+
# lua-resty-mysql
88+
# https://github.com/openresty/lua-resty-mysql/releases
89+
ARG VER_OPENRESTY_MYSQL=0.22
90+
ENV VER_OPENRESTY_MYSQL=$VER_OPENRESTY_MYSQL
91+
92+
# lua-resty-redis
93+
# https://github.com/openresty/lua-resty-redis/releases
94+
ARG VER_OPENRESTY_REDIS=0.29
95+
ENV VER_OPENRESTY_REDIS=$VER_OPENRESTY_REDIS
96+
97+
# lua-resty-shell
98+
# https://github.com/openresty/lua-resty-shell/releases
99+
ARG VER_OPENRESTY_SHELL=0.03
100+
ENV VER_OPENRESTY_SHELL=$VER_OPENRESTY_SHELL
101+
102+
# lua-resty-upstream-healthcheck
103+
# https://github.com/openresty/lua-resty-upstream-healthcheck/releases
104+
ARG VER_OPENRESTY_HEALTHCHECK=0.06
105+
ENV VER_OPENRESTY_HEALTHCHECK=$VER_OPENRESTY_HEALTHCHECK
106+
107+
# lua-resty-websocket
108+
# https://github.com/openresty/lua-resty-websocket/releases
109+
ARG VER_OPENRESTY_WEBSOCKET=0.07
110+
ENV VER_OPENRESTY_WEBSOCKET=$VER_OPENRESTY_WEBSOCKET
111+
112+
# lua-upstream-nginx-module
113+
# https://github.com/openresty/lua-upstream-nginx-module/releases
114+
ARG VER_LUA_UPSTREAM=0.07
115+
ENV VER_LUA_UPSTREAM=$VER_LUA_UPSTREAM
116+
117+
# nginx-lua-prometheus
118+
# https://github.com/knyar/nginx-lua-prometheus/releases
119+
ARG VER_PROMETHEUS=0.20200523
120+
ENV VER_PROMETHEUS=$VER_PROMETHEUS
121+
122+
# stream-lua-nginx-module
123+
# https://github.com/openresty/stream-lua-nginx-module/releases
124+
ARG VER_OPENRESTY_STREAMLUA=0.0.8
125+
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126+
127+
# https://github.com/nginx/nginx/releases
128+
ARG VER_NGINX=1.19.5
129+
ENV VER_NGINX=$VER_NGINX
130+
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131+
ENV NGX_CFLAGS=$NGX_CFLAGS
132+
ARG NGX_LDOPT="-Wl,-rpath,/usr/local/lib -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie"
133+
ENV NGX_LDOPT=$NGX_LDOPT
134+
ARG NGINX_BUILD_CONFIG="\
135+
--prefix=/etc/nginx \
136+
--sbin-path=/usr/sbin/nginx \
137+
--modules-path=/usr/lib/nginx/modules \
138+
--conf-path=/etc/nginx/nginx.conf \
139+
--error-log-path=/var/log/nginx/error.log \
140+
--http-log-path=/var/log/nginx/access.log \
141+
--pid-path=/var/run/nginx.pid \
142+
--lock-path=/var/run/nginx.lock \
143+
--http-client-body-temp-path=/var/cache/nginx/client_temp \
144+
--http-proxy-temp-path=/var/cache/nginx/proxy_temp \
145+
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
146+
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
147+
--http-scgi-temp-path=/var/cache/nginx/scgi_temp \
148+
--with-perl_modules_path=/usr/lib/perl5/vendor_perl \
149+
--user=nginx \
150+
--group=nginx \
151+
--with-compat \
152+
--with-file-aio \
153+
--with-threads \
154+
--with-http_addition_module \
155+
--with-http_auth_request_module \
156+
--with-http_dav_module \
157+
--with-http_flv_module \
158+
--with-http_gunzip_module \
159+
--with-http_gzip_static_module \
160+
--with-http_mp4_module \
161+
--with-http_random_index_module \
162+
--with-http_realip_module \
163+
--with-http_secure_link_module \
164+
--with-http_slice_module \
165+
--with-http_ssl_module \
166+
--with-http_stub_status_module \
167+
--with-http_sub_module \
168+
--with-http_v2_module \
169+
--with-mail \
170+
--with-mail_ssl_module \
171+
--with-stream \
172+
--with-stream_realip_module \
173+
--with-stream_ssl_module \
174+
--with-stream_ssl_preread_module \
175+
--add-module=/lua-nginx-module-${VER_LUA_NGINX_MODULE} \
176+
--add-module=/ngx_devel_kit-${VER_NGX_DEVEL_KIT} \
177+
--add-module=/lua-upstream-nginx-module-${VER_LUA_UPSTREAM} \
178+
"
179+
ENV NGINX_BUILD_CONFIG=$NGINX_BUILD_CONFIG
180+
181+
ARG BUILD_DEPS="\
182+
GeoIP-devel \
183+
ca-certificates \
184+
gcc-c++ \
185+
gzip \
186+
make \
187+
openssl-devel \
188+
pcre-devel \
189+
tar \
190+
unzip \
191+
zlib-devel \
192+
"
193+
ENV BUILD_DEPS=$BUILD_DEPS
194+
195+
ARG NGINX_BUILD_DEPS=""
196+
ENV NGINX_BUILD_DEPS=$NGINX_BUILD_DEPS
197+
198+
####################################
199+
# Build Nginx with support for LUA #
200+
####################################
201+
FROM base AS builder
202+
203+
COPY tpl/Makefile Makefile
204+
205+
# TODO: NGINX_BUILD_CONFIG not updated
206+
# hadolint ignore=SC2086
207+
RUN set -eux \
208+
&& yum makecache \
209+
&& yum install -y \
210+
$BUILD_DEPS \
211+
$NGINX_BUILD_DEPS \
212+
&& [ $EXTENDED_IMAGE -eq 1 ] && \
213+
NGINX_BUILD_CONFIG="${NGINX_BUILD_CONFIG} \
214+
--add-module=/headers-more-nginx-module-${VER_OPENRESTY_HEADERS} \
215+
--add-module=/stream-lua-nginx-module-${VER_OPENRESTY_STREAMLUA} \
216+
" \
217+
&& make -j "$(nproc)" deps \
218+
&& make -j "$(nproc)" core \
219+
&& yum clean all \
220+
&& rm -rf /var/cache/yum
221+
222+
RUN set -eux \
223+
# envsubst
224+
# ##############################################################################
225+
&& yum makecache \
226+
&& yum install -y \
227+
gettext \
228+
&& yum clean all \
229+
&& rm -rf /var/cache/yum
230+
231+
##########################################
232+
# Combine everything with minimal layers #
233+
##########################################
234+
FROM amazonlinux:2.0.20200722.0
235+
236+
# http://label-schema.org/rc1/
237+
LABEL maintainer="Fabio Cicerchia <info@fabiocicerchia.it>" \
238+
org.label-schema.build-date=$BUILD_DATE \
239+
org.label-schema.description="Nginx $VER_NGINX with Lua support based on $DOCKER_IMAGE_OS $DOCKER_IMAGE_TAG." \
240+
org.label-schema.docker.cmd="docker run -p 80:80 -d $DOCKER_IMAGE:$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
241+
org.label-schema.name="$DOCKER_IMAGE" \
242+
org.label-schema.schema-version="1.0" \
243+
org.label-schema.url="https://github.com/$DOCKER_IMAGE" \
244+
org.label-schema.vcs-ref=$VCS_REF \
245+
org.label-schema.vcs-url="https://github.com/$DOCKER_IMAGE" \
246+
org.label-schema.version="$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
247+
versions.extended=${EXTENDED_IMAGE} \
248+
versions.headers-more-nginx-module=${VER_OPENRESTY_HEADERS} \
249+
versions.lua-nginx-module=${VER_LUA_NGINX_MODULE} \
250+
versions.lua-resty-cookie=${VER_CLOUDFLARE_COOKIE} \
251+
versions.lua-resty-core=${VER_LUA_RESTY_CORE} \
252+
versions.lua-resty-dns=${VER_OPENRESTY_DNS} \
253+
versions.lua-resty-lrucache=${VER_LUA_RESTY_LRUCACHE} \
254+
versions.lua-resty-memcached=${VER_OPENRESTY_MEMCACHED} \
255+
versions.lua-resty-mysql=${VER_OPENRESTY_MYSQL} \
256+
versions.lua-resty-redis=${VER_OPENRESTY_REDIS} \
257+
versions.lua-resty-shell=${VER_OPENRESTY_SHELL} \
258+
versions.lua-resty-upstream-healthcheck=${VER_OPENRESTY_HEALTHCHECK} \
259+
versions.lua-resty-websocket=${VER_OPENRESTY_WEBSOCKET} \
260+
versions.lua-upstream=${VER_LUA_UPSTREAM} \
261+
versions.luajit2=${VER_LUAJIT} \
262+
versions.nginx-lua-prometheus=${VER_PROMETHEUS} \
263+
versions.nginx=${VER_NGINX} \
264+
versions.ngx_devel_kit=${VER_NGX_DEVEL_KIT} \
265+
versions.os=${DOCKER_IMAGE_TAG} \
266+
versions.stream-lua-nginx-module=${VER_OPENRESTY_STREAMLUA}
267+
268+
ARG PKG_DEPS="\
269+
GeoIP-devel \
270+
ca-certificates \
271+
openssl-devel \
272+
pcre-devel \
273+
zlib-devel \
274+
"
275+
ENV PKG_DEPS=$PKG_DEPS
276+
277+
COPY --from=builder /etc/nginx /etc/nginx
278+
COPY --from=builder /usr/local/lib /usr/local/lib
279+
COPY --from=builder /usr/local/share/lua /usr/local/share/lua
280+
COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
281+
COPY --from=builder /usr/sbin/nginx-debug /usr/sbin/nginx-debug
282+
COPY --from=builder /var/cache/nginx /var/cache/nginx
283+
COPY --from=builder /usr/bin/envsubst /usr/local/bin/envsubst
284+
285+
SHELL ["/bin/sh", "-o", "pipefail", "-c"]
286+
287+
# hadolint ignore=SC2086
288+
RUN set -eux \
289+
&& yum makecache \
290+
&& yum install -y \
291+
$PKG_DEPS \
292+
shadow-utils \
293+
# Bring in tzdata so users could set the timezones through the environment
294+
# variables
295+
&& yum install -y tzdata \
296+
# Bring in curl and ca-certificates to make registering on DNS SD easier
297+
&& yum install -y curl ca-certificates \
298+
# forward request and error logs to docker log collector
299+
&& mkdir -p /var/log/nginx \
300+
&& ln -sf /dev/stdout /var/log/nginx/access.log \
301+
&& ln -sf /dev/stderr /var/log/nginx/error.log \
302+
# create nginx user/group first, to be consistent throughout docker variants
303+
&& groupadd --system --gid 101 nginx \
304+
&& useradd --system --gid nginx --no-create-home --home /nonexistent --comment "nginx user" --shell /bin/false --uid 101 nginx \
305+
&& mkdir /docker-entrypoint.d \
306+
# Cleanup
307+
# ##############################################################################
308+
&& yum remove -y \
309+
shadow-utils \
310+
&& yum clean all \
311+
&& rm -rf /var/cache/yum
312+
313+
COPY tpl/docker-entrypoint.sh /
314+
COPY tpl/10-listen-on-ipv6-by-default.sh /docker-entrypoint.d/
315+
COPY tpl/20-envsubst-on-templates.sh /docker-entrypoint.d/
316+
317+
# smoke test
318+
# ##############################################################################
319+
RUN envsubst -V \
320+
&& nginx -V \
321+
&& nginx -t
322+
323+
EXPOSE 80 443
324+
325+
HEALTHCHECK --interval=30s --timeout=3s CMD curl --fail http://localhost/ || exit 1
326+
327+
# Override stop signal to stop process gracefully
328+
STOPSIGNAL SIGQUIT
329+
330+
ENTRYPOINT ["/docker-entrypoint.sh"]
331+
332+
CMD ["nginx", "-g", "daemon off;"]

‎nginx/1.19.5/centos/8/Dockerfile

+331
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,331 @@
1+
# __ __
2+
# .-----.-----.|__|.-----.--.--.______| |.--.--.---.-.
3+
# | | _ || || |_ _|______| || | | _ |
4+
# |__|__|___ ||__||__|__|__.__| |__||_____|___._|
5+
# |_____|
6+
#
7+
# Copyright (c) 2020 Fabio Cicerchia. https://fabiocicerchia.it. MIT License
8+
# Repo: https://github.com/fabiocicerchia/nginx-lua
9+
10+
FROM centos:8 AS base
11+
12+
#############################
13+
# Settings Common Variables #
14+
#############################
15+
ARG DOCKER_IMAGE=fabiocicerchia/nginx-lua
16+
ENV DOCKER_IMAGE=$DOCKER_IMAGE
17+
ARG DOCKER_IMAGE_OS=centos
18+
ENV DOCKER_IMAGE_OS=$DOCKER_IMAGE_OS
19+
ARG DOCKER_IMAGE_TAG=8
20+
ENV DOCKER_IMAGE_TAG=$DOCKER_IMAGE_TAG
21+
22+
ARG BUILD_DATE
23+
ENV BUILD_DATE=$BUILD_DATE
24+
ARG VCS_REF
25+
ENV VCS_REF=$VCS_REF
26+
27+
ARG EXTENDED_IMAGE=1
28+
ENV EXTENDED_IMAGE=$EXTENDED_IMAGE
29+
30+
# ngx_devel_kit
31+
# https://github.com/vision5/ngx_devel_kit/releases
32+
# The NDK is now considered to be stable.
33+
ARG VER_NGX_DEVEL_KIT=0.3.1
34+
ENV VER_NGX_DEVEL_KIT=$VER_NGX_DEVEL_KIT
35+
36+
# luajit2
37+
# https://github.com/openresty/luajit2/releases
38+
ARG VER_LUAJIT=2.1-20201012-2
39+
ENV VER_LUAJIT=$VER_LUAJIT
40+
ARG LUAJIT_LIB=/usr/local/lib
41+
ENV LUAJIT_LIB=$LUAJIT_LIB
42+
ARG LUAJIT_INC=/usr/local/include/luajit-2.1
43+
ENV LUAJIT_INC=$LUAJIT_INC
44+
ARG LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH
45+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH
46+
47+
# lua-nginx-module
48+
# https://github.com/openresty/lua-nginx-module/releases
49+
# Production ready.
50+
ARG VER_LUA_NGINX_MODULE=0.10.17
51+
ENV VER_LUA_NGINX_MODULE=$VER_LUA_NGINX_MODULE
52+
53+
# lua-resty-core
54+
# https://github.com/openresty/lua-resty-core/releases
55+
# This library is production ready.
56+
ARG VER_LUA_RESTY_CORE=0.1.19
57+
ENV VER_LUA_RESTY_CORE=$VER_LUA_RESTY_CORE
58+
ARG LUA_LIB_DIR=/usr/local/share/lua/5.1
59+
ENV LUA_LIB_DIR=$LUA_LIB_DIR
60+
61+
# lua-resty-lrucache
62+
# https://github.com/openresty/lua-resty-lrucache/releases
63+
# This library is considered production ready.
64+
ARG VER_LUA_RESTY_LRUCACHE=0.10
65+
ENV VER_LUA_RESTY_LRUCACHE=$VER_LUA_RESTY_LRUCACHE
66+
67+
# headers-more-nginx-module
68+
# https://github.com/openresty/headers-more-nginx-module/commits/master
69+
ARG VER_OPENRESTY_HEADERS=d6d7ebab3c0c5b32ab421ba186783d3e5d2c6a17
70+
ENV VER_OPENRESTY_HEADERS=$VER_OPENRESTY_HEADERS
71+
72+
# lua-resty-cookie
73+
# https://github.com/cloudflare/lua-resty-cookie/commits/master
74+
ARG VER_CLOUDFLARE_COOKIE=303e32e512defced053a6484bc0745cf9dc0d39e
75+
ENV VER_CLOUDFLARE_COOKIE=$VER_CLOUDFLARE_COOKIE
76+
77+
# lua-resty-dns
78+
# https://github.com/openresty/lua-resty-dns/releases
79+
ARG VER_OPENRESTY_DNS=0.21
80+
ENV VER_OPENRESTY_DNS=$VER_OPENRESTY_DNS
81+
82+
# lua-resty-memcached
83+
# https://github.com/openresty/lua-resty-memcached/releases
84+
ARG VER_OPENRESTY_MEMCACHED=0.15
85+
ENV VER_OPENRESTY_MEMCACHED=$VER_OPENRESTY_MEMCACHED
86+
87+
# lua-resty-mysql
88+
# https://github.com/openresty/lua-resty-mysql/releases
89+
ARG VER_OPENRESTY_MYSQL=0.22
90+
ENV VER_OPENRESTY_MYSQL=$VER_OPENRESTY_MYSQL
91+
92+
# lua-resty-redis
93+
# https://github.com/openresty/lua-resty-redis/releases
94+
ARG VER_OPENRESTY_REDIS=0.29
95+
ENV VER_OPENRESTY_REDIS=$VER_OPENRESTY_REDIS
96+
97+
# lua-resty-shell
98+
# https://github.com/openresty/lua-resty-shell/releases
99+
ARG VER_OPENRESTY_SHELL=0.03
100+
ENV VER_OPENRESTY_SHELL=$VER_OPENRESTY_SHELL
101+
102+
# lua-resty-upstream-healthcheck
103+
# https://github.com/openresty/lua-resty-upstream-healthcheck/releases
104+
ARG VER_OPENRESTY_HEALTHCHECK=0.06
105+
ENV VER_OPENRESTY_HEALTHCHECK=$VER_OPENRESTY_HEALTHCHECK
106+
107+
# lua-resty-websocket
108+
# https://github.com/openresty/lua-resty-websocket/releases
109+
ARG VER_OPENRESTY_WEBSOCKET=0.07
110+
ENV VER_OPENRESTY_WEBSOCKET=$VER_OPENRESTY_WEBSOCKET
111+
112+
# lua-upstream-nginx-module
113+
# https://github.com/openresty/lua-upstream-nginx-module/releases
114+
ARG VER_LUA_UPSTREAM=0.07
115+
ENV VER_LUA_UPSTREAM=$VER_LUA_UPSTREAM
116+
117+
# nginx-lua-prometheus
118+
# https://github.com/knyar/nginx-lua-prometheus/releases
119+
ARG VER_PROMETHEUS=0.20200523
120+
ENV VER_PROMETHEUS=$VER_PROMETHEUS
121+
122+
# stream-lua-nginx-module
123+
# https://github.com/openresty/stream-lua-nginx-module/releases
124+
ARG VER_OPENRESTY_STREAMLUA=0.0.8
125+
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126+
127+
# https://github.com/nginx/nginx/releases
128+
ARG VER_NGINX=1.19.5
129+
ENV VER_NGINX=$VER_NGINX
130+
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131+
ENV NGX_CFLAGS=$NGX_CFLAGS
132+
ARG NGX_LDOPT="-Wl,-rpath,/usr/local/lib -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie"
133+
ENV NGX_LDOPT=$NGX_LDOPT
134+
ARG NGINX_BUILD_CONFIG="\
135+
--prefix=/etc/nginx \
136+
--sbin-path=/usr/sbin/nginx \
137+
--modules-path=/usr/lib/nginx/modules \
138+
--conf-path=/etc/nginx/nginx.conf \
139+
--error-log-path=/var/log/nginx/error.log \
140+
--http-log-path=/var/log/nginx/access.log \
141+
--pid-path=/var/run/nginx.pid \
142+
--lock-path=/var/run/nginx.lock \
143+
--http-client-body-temp-path=/var/cache/nginx/client_temp \
144+
--http-proxy-temp-path=/var/cache/nginx/proxy_temp \
145+
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
146+
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
147+
--http-scgi-temp-path=/var/cache/nginx/scgi_temp \
148+
--with-perl_modules_path=/usr/lib/perl5/vendor_perl \
149+
--user=nginx \
150+
--group=nginx \
151+
--with-compat \
152+
--with-file-aio \
153+
--with-threads \
154+
--with-http_addition_module \
155+
--with-http_auth_request_module \
156+
--with-http_dav_module \
157+
--with-http_flv_module \
158+
--with-http_gunzip_module \
159+
--with-http_gzip_static_module \
160+
--with-http_mp4_module \
161+
--with-http_random_index_module \
162+
--with-http_realip_module \
163+
--with-http_secure_link_module \
164+
--with-http_slice_module \
165+
--with-http_ssl_module \
166+
--with-http_stub_status_module \
167+
--with-http_sub_module \
168+
--with-http_v2_module \
169+
--with-mail \
170+
--with-mail_ssl_module \
171+
--with-stream \
172+
--with-stream_realip_module \
173+
--with-stream_ssl_module \
174+
--with-stream_ssl_preread_module \
175+
--add-module=/lua-nginx-module-${VER_LUA_NGINX_MODULE} \
176+
--add-module=/ngx_devel_kit-${VER_NGX_DEVEL_KIT} \
177+
--add-module=/lua-upstream-nginx-module-${VER_LUA_UPSTREAM} \
178+
"
179+
ENV NGINX_BUILD_CONFIG=$NGINX_BUILD_CONFIG
180+
181+
ARG BUILD_DEPS="\
182+
GeoIP-devel \
183+
ca-certificates \
184+
gcc-c++ \
185+
gzip \
186+
make \
187+
openssl-devel \
188+
pcre-devel \
189+
tar \
190+
unzip \
191+
zlib-devel \
192+
"
193+
ENV BUILD_DEPS=$BUILD_DEPS
194+
195+
ARG NGINX_BUILD_DEPS=""
196+
ENV NGINX_BUILD_DEPS=$NGINX_BUILD_DEPS
197+
198+
####################################
199+
# Build Nginx with support for LUA #
200+
####################################
201+
FROM base AS builder
202+
203+
COPY tpl/Makefile Makefile
204+
205+
# TODO: NGINX_BUILD_CONFIG not updated
206+
# hadolint ignore=SC2086
207+
RUN set -eux \
208+
&& yum makecache \
209+
&& yum install -y epel-release \
210+
&& yum install -y \
211+
$BUILD_DEPS \
212+
$NGINX_BUILD_DEPS \
213+
&& [ $EXTENDED_IMAGE -eq 1 ] && \
214+
NGINX_BUILD_CONFIG="${NGINX_BUILD_CONFIG} \
215+
--add-module=/headers-more-nginx-module-${VER_OPENRESTY_HEADERS} \
216+
--add-module=/stream-lua-nginx-module-${VER_OPENRESTY_STREAMLUA} \
217+
" \
218+
&& make -j "$(nproc)" deps \
219+
&& make -j "$(nproc)" core \
220+
&& yum clean all \
221+
&& rm -rf /var/cache/yum
222+
223+
RUN set -eux \
224+
# envsubst
225+
# ##############################################################################
226+
&& yum makecache \
227+
&& yum install -y \
228+
gettext \
229+
&& yum clean all \
230+
&& rm -rf /var/cache/yum
231+
232+
##########################################
233+
# Combine everything with minimal layers #
234+
##########################################
235+
FROM centos:8
236+
237+
# http://label-schema.org/rc1/
238+
LABEL maintainer="Fabio Cicerchia <info@fabiocicerchia.it>" \
239+
org.label-schema.build-date=$BUILD_DATE \
240+
org.label-schema.description="Nginx $VER_NGINX with Lua support based on $DOCKER_IMAGE_OS $DOCKER_IMAGE_TAG." \
241+
org.label-schema.docker.cmd="docker run -p 80:80 -d $DOCKER_IMAGE:$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
242+
org.label-schema.name="$DOCKER_IMAGE" \
243+
org.label-schema.schema-version="1.0" \
244+
org.label-schema.url="https://github.com/$DOCKER_IMAGE" \
245+
org.label-schema.vcs-ref=$VCS_REF \
246+
org.label-schema.vcs-url="https://github.com/$DOCKER_IMAGE" \
247+
org.label-schema.version="$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
248+
versions.extended=${EXTENDED_IMAGE} \
249+
versions.headers-more-nginx-module=${VER_OPENRESTY_HEADERS} \
250+
versions.lua-nginx-module=${VER_LUA_NGINX_MODULE} \
251+
versions.lua-resty-cookie=${VER_CLOUDFLARE_COOKIE} \
252+
versions.lua-resty-core=${VER_LUA_RESTY_CORE} \
253+
versions.lua-resty-dns=${VER_OPENRESTY_DNS} \
254+
versions.lua-resty-lrucache=${VER_LUA_RESTY_LRUCACHE} \
255+
versions.lua-resty-memcached=${VER_OPENRESTY_MEMCACHED} \
256+
versions.lua-resty-mysql=${VER_OPENRESTY_MYSQL} \
257+
versions.lua-resty-redis=${VER_OPENRESTY_REDIS} \
258+
versions.lua-resty-shell=${VER_OPENRESTY_SHELL} \
259+
versions.lua-resty-upstream-healthcheck=${VER_OPENRESTY_HEALTHCHECK} \
260+
versions.lua-resty-websocket=${VER_OPENRESTY_WEBSOCKET} \
261+
versions.lua-upstream=${VER_LUA_UPSTREAM} \
262+
versions.luajit2=${VER_LUAJIT} \
263+
versions.nginx-lua-prometheus=${VER_PROMETHEUS} \
264+
versions.nginx=${VER_NGINX} \
265+
versions.ngx_devel_kit=${VER_NGX_DEVEL_KIT} \
266+
versions.os=${DOCKER_IMAGE_TAG} \
267+
versions.stream-lua-nginx-module=${VER_OPENRESTY_STREAMLUA}
268+
269+
ARG PKG_DEPS="\
270+
GeoIP-devel \
271+
ca-certificates \
272+
openssl-devel \
273+
pcre-devel \
274+
zlib-devel \
275+
"
276+
ENV PKG_DEPS=$PKG_DEPS
277+
278+
COPY --from=builder /etc/nginx /etc/nginx
279+
COPY --from=builder /usr/local/lib /usr/local/lib
280+
COPY --from=builder /usr/local/share/lua /usr/local/share/lua
281+
COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
282+
COPY --from=builder /usr/sbin/nginx-debug /usr/sbin/nginx-debug
283+
COPY --from=builder /var/cache/nginx /var/cache/nginx
284+
COPY --from=builder /usr/bin/envsubst /usr/local/bin/envsubst
285+
286+
SHELL ["/bin/sh", "-o", "pipefail", "-c"]
287+
288+
# hadolint ignore=SC2086
289+
RUN set -eux \
290+
&& yum makecache \
291+
&& yum install -y epel-release \
292+
&& yum install -y \
293+
$PKG_DEPS \
294+
# Bring in tzdata so users could set the timezones through the environment
295+
# variables
296+
&& yum install -y tzdata \
297+
# Bring in curl and ca-certificates to make registering on DNS SD easier
298+
&& yum install -y curl ca-certificates \
299+
# forward request and error logs to docker log collector
300+
&& mkdir -p /var/log/nginx \
301+
&& ln -sf /dev/stdout /var/log/nginx/access.log \
302+
&& ln -sf /dev/stderr /var/log/nginx/error.log \
303+
# create nginx user/group first, to be consistent throughout docker variants
304+
&& groupadd --system --gid 101 nginx \
305+
&& useradd --system --gid nginx --no-create-home --home /nonexistent --comment "nginx user" --shell /bin/false --uid 101 nginx \
306+
&& mkdir /docker-entrypoint.d \
307+
# Cleanup
308+
# ##############################################################################
309+
&& yum clean all \
310+
&& rm -rf /var/cache/yum
311+
312+
COPY tpl/docker-entrypoint.sh /
313+
COPY tpl/10-listen-on-ipv6-by-default.sh /docker-entrypoint.d/
314+
COPY tpl/20-envsubst-on-templates.sh /docker-entrypoint.d/
315+
316+
# smoke test
317+
# ##############################################################################
318+
RUN envsubst -V \
319+
&& nginx -V \
320+
&& nginx -t
321+
322+
EXPOSE 80 443
323+
324+
HEALTHCHECK --interval=30s --timeout=3s CMD curl --fail http://localhost/ || exit 1
325+
326+
# Override stop signal to stop process gracefully
327+
STOPSIGNAL SIGQUIT
328+
329+
ENTRYPOINT ["/docker-entrypoint.sh"]
330+
331+
CMD ["nginx", "-g", "daemon off;"]

‎nginx/1.19.5/debian/10.6/Dockerfile

+330
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,330 @@
1+
# __ __
2+
# .-----.-----.|__|.-----.--.--.______| |.--.--.---.-.
3+
# | | _ || || |_ _|______| || | | _ |
4+
# |__|__|___ ||__||__|__|__.__| |__||_____|___._|
5+
# |_____|
6+
#
7+
# Copyright (c) 2020 Fabio Cicerchia. https://fabiocicerchia.it. MIT License
8+
# Repo: https://github.com/fabiocicerchia/nginx-lua
9+
10+
FROM debian:10.6 AS base
11+
12+
#############################
13+
# Settings Common Variables #
14+
#############################
15+
ARG DOCKER_IMAGE=fabiocicerchia/nginx-lua
16+
ENV DOCKER_IMAGE=$DOCKER_IMAGE
17+
ARG DOCKER_IMAGE_OS=debian
18+
ENV DOCKER_IMAGE_OS=$DOCKER_IMAGE_OS
19+
ARG DOCKER_IMAGE_TAG=10.6
20+
ENV DOCKER_IMAGE_TAG=$DOCKER_IMAGE_TAG
21+
22+
ARG BUILD_DATE
23+
ENV BUILD_DATE=$BUILD_DATE
24+
ARG VCS_REF
25+
ENV VCS_REF=$VCS_REF
26+
27+
ARG EXTENDED_IMAGE=1
28+
ENV EXTENDED_IMAGE=$EXTENDED_IMAGE
29+
30+
# ngx_devel_kit
31+
# https://github.com/vision5/ngx_devel_kit/releases
32+
# The NDK is now considered to be stable.
33+
ARG VER_NGX_DEVEL_KIT=0.3.1
34+
ENV VER_NGX_DEVEL_KIT=$VER_NGX_DEVEL_KIT
35+
36+
# luajit2
37+
# https://github.com/openresty/luajit2/releases
38+
ARG VER_LUAJIT=2.1-20201012-2
39+
ENV VER_LUAJIT=$VER_LUAJIT
40+
ARG LUAJIT_LIB=/usr/local/lib
41+
ENV LUAJIT_LIB=$LUAJIT_LIB
42+
ARG LUAJIT_INC=/usr/local/include/luajit-2.1
43+
ENV LUAJIT_INC=$LUAJIT_INC
44+
ARG LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH
45+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH
46+
47+
# lua-nginx-module
48+
# https://github.com/openresty/lua-nginx-module/releases
49+
# Production ready.
50+
ARG VER_LUA_NGINX_MODULE=0.10.17
51+
ENV VER_LUA_NGINX_MODULE=$VER_LUA_NGINX_MODULE
52+
53+
# lua-resty-core
54+
# https://github.com/openresty/lua-resty-core/releases
55+
# This library is production ready.
56+
ARG VER_LUA_RESTY_CORE=0.1.19
57+
ENV VER_LUA_RESTY_CORE=$VER_LUA_RESTY_CORE
58+
ARG LUA_LIB_DIR=/usr/local/share/lua/5.1
59+
ENV LUA_LIB_DIR=$LUA_LIB_DIR
60+
61+
# lua-resty-lrucache
62+
# https://github.com/openresty/lua-resty-lrucache/releases
63+
# This library is considered production ready.
64+
ARG VER_LUA_RESTY_LRUCACHE=0.10
65+
ENV VER_LUA_RESTY_LRUCACHE=$VER_LUA_RESTY_LRUCACHE
66+
67+
# headers-more-nginx-module
68+
# https://github.com/openresty/headers-more-nginx-module/commits/master
69+
ARG VER_OPENRESTY_HEADERS=d6d7ebab3c0c5b32ab421ba186783d3e5d2c6a17
70+
ENV VER_OPENRESTY_HEADERS=$VER_OPENRESTY_HEADERS
71+
72+
# lua-resty-cookie
73+
# https://github.com/cloudflare/lua-resty-cookie/commits/master
74+
ARG VER_CLOUDFLARE_COOKIE=303e32e512defced053a6484bc0745cf9dc0d39e
75+
ENV VER_CLOUDFLARE_COOKIE=$VER_CLOUDFLARE_COOKIE
76+
77+
# lua-resty-dns
78+
# https://github.com/openresty/lua-resty-dns/releases
79+
ARG VER_OPENRESTY_DNS=0.21
80+
ENV VER_OPENRESTY_DNS=$VER_OPENRESTY_DNS
81+
82+
# lua-resty-memcached
83+
# https://github.com/openresty/lua-resty-memcached/releases
84+
ARG VER_OPENRESTY_MEMCACHED=0.15
85+
ENV VER_OPENRESTY_MEMCACHED=$VER_OPENRESTY_MEMCACHED
86+
87+
# lua-resty-mysql
88+
# https://github.com/openresty/lua-resty-mysql/releases
89+
ARG VER_OPENRESTY_MYSQL=0.22
90+
ENV VER_OPENRESTY_MYSQL=$VER_OPENRESTY_MYSQL
91+
92+
# lua-resty-redis
93+
# https://github.com/openresty/lua-resty-redis/releases
94+
ARG VER_OPENRESTY_REDIS=0.29
95+
ENV VER_OPENRESTY_REDIS=$VER_OPENRESTY_REDIS
96+
97+
# lua-resty-shell
98+
# https://github.com/openresty/lua-resty-shell/releases
99+
ARG VER_OPENRESTY_SHELL=0.03
100+
ENV VER_OPENRESTY_SHELL=$VER_OPENRESTY_SHELL
101+
102+
# lua-resty-upstream-healthcheck
103+
# https://github.com/openresty/lua-resty-upstream-healthcheck/releases
104+
ARG VER_OPENRESTY_HEALTHCHECK=0.06
105+
ENV VER_OPENRESTY_HEALTHCHECK=$VER_OPENRESTY_HEALTHCHECK
106+
107+
# lua-resty-websocket
108+
# https://github.com/openresty/lua-resty-websocket/releases
109+
ARG VER_OPENRESTY_WEBSOCKET=0.07
110+
ENV VER_OPENRESTY_WEBSOCKET=$VER_OPENRESTY_WEBSOCKET
111+
112+
# lua-upstream-nginx-module
113+
# https://github.com/openresty/lua-upstream-nginx-module/releases
114+
ARG VER_LUA_UPSTREAM=0.07
115+
ENV VER_LUA_UPSTREAM=$VER_LUA_UPSTREAM
116+
117+
# nginx-lua-prometheus
118+
# https://github.com/knyar/nginx-lua-prometheus/releases
119+
ARG VER_PROMETHEUS=0.20200523
120+
ENV VER_PROMETHEUS=$VER_PROMETHEUS
121+
122+
# stream-lua-nginx-module
123+
# https://github.com/openresty/stream-lua-nginx-module/releases
124+
ARG VER_OPENRESTY_STREAMLUA=0.0.8
125+
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126+
127+
# https://github.com/nginx/nginx/releases
128+
ARG VER_NGINX=1.19.5
129+
ENV VER_NGINX=$VER_NGINX
130+
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131+
ENV NGX_CFLAGS=$NGX_CFLAGS
132+
ARG NGX_LDOPT="-Wl,-rpath,/usr/local/lib -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie"
133+
ENV NGX_LDOPT=$NGX_LDOPT
134+
ARG NGINX_BUILD_CONFIG="\
135+
--prefix=/etc/nginx \
136+
--sbin-path=/usr/sbin/nginx \
137+
--modules-path=/usr/lib/nginx/modules \
138+
--conf-path=/etc/nginx/nginx.conf \
139+
--error-log-path=/var/log/nginx/error.log \
140+
--http-log-path=/var/log/nginx/access.log \
141+
--pid-path=/var/run/nginx.pid \
142+
--lock-path=/var/run/nginx.lock \
143+
--http-client-body-temp-path=/var/cache/nginx/client_temp \
144+
--http-proxy-temp-path=/var/cache/nginx/proxy_temp \
145+
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
146+
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
147+
--http-scgi-temp-path=/var/cache/nginx/scgi_temp \
148+
--with-perl_modules_path=/usr/lib/perl5/vendor_perl \
149+
--user=nginx \
150+
--group=nginx \
151+
--with-compat \
152+
--with-file-aio \
153+
--with-threads \
154+
--with-http_addition_module \
155+
--with-http_auth_request_module \
156+
--with-http_dav_module \
157+
--with-http_flv_module \
158+
--with-http_gunzip_module \
159+
--with-http_gzip_static_module \
160+
--with-http_mp4_module \
161+
--with-http_random_index_module \
162+
--with-http_realip_module \
163+
--with-http_secure_link_module \
164+
--with-http_slice_module \
165+
--with-http_ssl_module \
166+
--with-http_stub_status_module \
167+
--with-http_sub_module \
168+
--with-http_v2_module \
169+
--with-mail \
170+
--with-mail_ssl_module \
171+
--with-stream \
172+
--with-stream_realip_module \
173+
--with-stream_ssl_module \
174+
--with-stream_ssl_preread_module \
175+
--add-module=/lua-nginx-module-${VER_LUA_NGINX_MODULE} \
176+
--add-module=/ngx_devel_kit-${VER_NGX_DEVEL_KIT} \
177+
--add-module=/lua-upstream-nginx-module-${VER_LUA_UPSTREAM} \
178+
"
179+
ENV NGINX_BUILD_CONFIG=$NGINX_BUILD_CONFIG
180+
181+
ENV DEBIAN_FRONTEND noninteractive
182+
183+
ARG BUILD_DEPS="\
184+
ca-certificates \
185+
curl \
186+
g++ \
187+
libgeoip-dev \
188+
libpcre3-dev \
189+
libssl-dev \
190+
make \
191+
unzip \
192+
zlib1g-dev \
193+
"
194+
ENV BUILD_DEPS=$BUILD_DEPS
195+
196+
ARG NGINX_BUILD_DEPS=""
197+
ENV NGINX_BUILD_DEPS=$NGINX_BUILD_DEPS
198+
199+
####################################
200+
# Build Nginx with support for LUA #
201+
####################################
202+
FROM base AS builder
203+
204+
COPY tpl/Makefile Makefile
205+
206+
# TODO: NGINX_BUILD_CONFIG not updated
207+
# hadolint ignore=SC2086
208+
RUN set -eux \
209+
&& apt-get update \
210+
&& apt-get install -y --no-install-recommends --no-install-suggests \
211+
apt-utils \
212+
&& apt-get install -y --no-install-recommends --no-install-suggests \
213+
$BUILD_DEPS \
214+
$NGINX_BUILD_DEPS \
215+
&& [ $EXTENDED_IMAGE -eq 1 ] && \
216+
NGINX_BUILD_CONFIG="${NGINX_BUILD_CONFIG} \
217+
--add-module=/headers-more-nginx-module-${VER_OPENRESTY_HEADERS} \
218+
--add-module=/stream-lua-nginx-module-${VER_OPENRESTY_STREAMLUA} \
219+
" \
220+
&& make -j "$(nproc)" deps \
221+
&& make -j "$(nproc)" core \
222+
&& rm -rf /var/lib/apt/lists/*
223+
224+
RUN set -eux \
225+
# envsubst
226+
# ##############################################################################
227+
&& apt-get update \
228+
&& apt-get install -y --no-install-recommends --no-install-suggests \
229+
gettext-base \
230+
&& rm -rf /var/lib/apt/lists/*
231+
232+
##########################################
233+
# Combine everything with minimal layers #
234+
##########################################
235+
FROM debian:10.6
236+
237+
# http://label-schema.org/rc1/
238+
LABEL maintainer="Fabio Cicerchia <info@fabiocicerchia.it>" \
239+
org.label-schema.build-date=$BUILD_DATE \
240+
org.label-schema.description="Nginx $VER_NGINX with Lua support based on $DOCKER_IMAGE_OS $DOCKER_IMAGE_TAG." \
241+
org.label-schema.docker.cmd="docker run -p 80:80 -d $DOCKER_IMAGE:$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
242+
org.label-schema.name="$DOCKER_IMAGE" \
243+
org.label-schema.schema-version="1.0" \
244+
org.label-schema.url="https://github.com/$DOCKER_IMAGE" \
245+
org.label-schema.vcs-ref=$VCS_REF \
246+
org.label-schema.vcs-url="https://github.com/$DOCKER_IMAGE" \
247+
org.label-schema.version="$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
248+
versions.extended=${EXTENDED_IMAGE} \
249+
versions.headers-more-nginx-module=${VER_OPENRESTY_HEADERS} \
250+
versions.lua-nginx-module=${VER_LUA_NGINX_MODULE} \
251+
versions.lua-resty-cookie=${VER_CLOUDFLARE_COOKIE} \
252+
versions.lua-resty-core=${VER_LUA_RESTY_CORE} \
253+
versions.lua-resty-dns=${VER_OPENRESTY_DNS} \
254+
versions.lua-resty-lrucache=${VER_LUA_RESTY_LRUCACHE} \
255+
versions.lua-resty-memcached=${VER_OPENRESTY_MEMCACHED} \
256+
versions.lua-resty-mysql=${VER_OPENRESTY_MYSQL} \
257+
versions.lua-resty-redis=${VER_OPENRESTY_REDIS} \
258+
versions.lua-resty-shell=${VER_OPENRESTY_SHELL} \
259+
versions.lua-resty-upstream-healthcheck=${VER_OPENRESTY_HEALTHCHECK} \
260+
versions.lua-resty-websocket=${VER_OPENRESTY_WEBSOCKET} \
261+
versions.lua-upstream=${VER_LUA_UPSTREAM} \
262+
versions.luajit2=${VER_LUAJIT} \
263+
versions.nginx-lua-prometheus=${VER_PROMETHEUS} \
264+
versions.nginx=${VER_NGINX} \
265+
versions.ngx_devel_kit=${VER_NGX_DEVEL_KIT} \
266+
versions.os=${DOCKER_IMAGE_TAG} \
267+
versions.stream-lua-nginx-module=${VER_OPENRESTY_STREAMLUA}
268+
269+
ARG PKG_DEPS="\
270+
ca-certificates \
271+
libgeoip-dev \
272+
libpcre3-dev \
273+
libssl-dev \
274+
zlib1g-dev \
275+
"
276+
ENV PKG_DEPS=$PKG_DEPS
277+
278+
COPY --from=builder /etc/nginx /etc/nginx
279+
COPY --from=builder /usr/local/lib /usr/local/lib
280+
COPY --from=builder /usr/local/share/lua /usr/local/share/lua
281+
COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
282+
COPY --from=builder /usr/sbin/nginx-debug /usr/sbin/nginx-debug
283+
COPY --from=builder /var/cache/nginx /var/cache/nginx
284+
COPY --from=builder /usr/bin/envsubst /usr/local/bin/envsubst
285+
286+
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
287+
288+
# hadolint ignore=SC2086
289+
RUN set -eux \
290+
&& apt-get update \
291+
&& apt-get install -y --no-install-recommends --no-install-suggests \
292+
$PKG_DEPS \
293+
# Bring in tzdata so users could set the timezones through the environment
294+
# variables
295+
&& apt-get install -y --no-install-recommends --no-install-suggests tzdata \
296+
# Bring in curl and ca-certificates to make registering on DNS SD easier
297+
&& apt-get install -y --no-install-recommends --no-install-suggests curl ca-certificates \
298+
# forward request and error logs to docker log collector
299+
&& mkdir -p /var/log/nginx \
300+
&& ln -sf /dev/stdout /var/log/nginx/access.log \
301+
&& ln -sf /dev/stderr /var/log/nginx/error.log \
302+
# create nginx user/group first, to be consistent throughout docker variants
303+
&& addgroup --system --gid 101 nginx \
304+
&& adduser --system --disabled-login --ingroup nginx --no-create-home --home /nonexistent --gecos "nginx user" --shell /bin/false --uid 101 nginx \
305+
&& mkdir /docker-entrypoint.d \
306+
# Cleanup
307+
# ##############################################################################
308+
&& apt-get autoremove -y \
309+
&& rm -rf /var/lib/apt/lists/*
310+
311+
COPY tpl/docker-entrypoint.sh /
312+
COPY tpl/10-listen-on-ipv6-by-default.sh /docker-entrypoint.d/
313+
COPY tpl/20-envsubst-on-templates.sh /docker-entrypoint.d/
314+
315+
# smoke test
316+
# ##############################################################################
317+
RUN envsubst -V \
318+
&& nginx -V \
319+
&& nginx -t
320+
321+
EXPOSE 80 443
322+
323+
HEALTHCHECK --interval=30s --timeout=3s CMD curl --fail http://localhost/ || exit 1
324+
325+
# Override stop signal to stop process gracefully
326+
STOPSIGNAL SIGQUIT
327+
328+
ENTRYPOINT ["/docker-entrypoint.sh"]
329+
330+
CMD ["nginx", "-g", "daemon off;"]

‎nginx/1.19.5/fedora/33/Dockerfile

+328
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,328 @@
1+
# __ __
2+
# .-----.-----.|__|.-----.--.--.______| |.--.--.---.-.
3+
# | | _ || || |_ _|______| || | | _ |
4+
# |__|__|___ ||__||__|__|__.__| |__||_____|___._|
5+
# |_____|
6+
#
7+
# Copyright (c) 2020 Fabio Cicerchia. https://fabiocicerchia.it. MIT License
8+
# Repo: https://github.com/fabiocicerchia/nginx-lua
9+
10+
FROM fedora:33 AS base
11+
12+
#############################
13+
# Settings Common Variables #
14+
#############################
15+
ARG DOCKER_IMAGE=fabiocicerchia/nginx-lua
16+
ENV DOCKER_IMAGE=$DOCKER_IMAGE
17+
ARG DOCKER_IMAGE_OS=fedora
18+
ENV DOCKER_IMAGE_OS=$DOCKER_IMAGE_OS
19+
ARG DOCKER_IMAGE_TAG=33
20+
ENV DOCKER_IMAGE_TAG=$DOCKER_IMAGE_TAG
21+
22+
ARG BUILD_DATE
23+
ENV BUILD_DATE=$BUILD_DATE
24+
ARG VCS_REF
25+
ENV VCS_REF=$VCS_REF
26+
27+
ARG EXTENDED_IMAGE=1
28+
ENV EXTENDED_IMAGE=$EXTENDED_IMAGE
29+
30+
# ngx_devel_kit
31+
# https://github.com/vision5/ngx_devel_kit/releases
32+
# The NDK is now considered to be stable.
33+
ARG VER_NGX_DEVEL_KIT=0.3.1
34+
ENV VER_NGX_DEVEL_KIT=$VER_NGX_DEVEL_KIT
35+
36+
# luajit2
37+
# https://github.com/openresty/luajit2/releases
38+
ARG VER_LUAJIT=2.1-20201012-2
39+
ENV VER_LUAJIT=$VER_LUAJIT
40+
ARG LUAJIT_LIB=/usr/local/lib
41+
ENV LUAJIT_LIB=$LUAJIT_LIB
42+
ARG LUAJIT_INC=/usr/local/include/luajit-2.1
43+
ENV LUAJIT_INC=$LUAJIT_INC
44+
ARG LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH
45+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH
46+
47+
# lua-nginx-module
48+
# https://github.com/openresty/lua-nginx-module/releases
49+
# Production ready.
50+
ARG VER_LUA_NGINX_MODULE=0.10.17
51+
ENV VER_LUA_NGINX_MODULE=$VER_LUA_NGINX_MODULE
52+
53+
# lua-resty-core
54+
# https://github.com/openresty/lua-resty-core/releases
55+
# This library is production ready.
56+
ARG VER_LUA_RESTY_CORE=0.1.19
57+
ENV VER_LUA_RESTY_CORE=$VER_LUA_RESTY_CORE
58+
ARG LUA_LIB_DIR=/usr/local/share/lua/5.1
59+
ENV LUA_LIB_DIR=$LUA_LIB_DIR
60+
61+
# lua-resty-lrucache
62+
# https://github.com/openresty/lua-resty-lrucache/releases
63+
# This library is considered production ready.
64+
ARG VER_LUA_RESTY_LRUCACHE=0.10
65+
ENV VER_LUA_RESTY_LRUCACHE=$VER_LUA_RESTY_LRUCACHE
66+
67+
# headers-more-nginx-module
68+
# https://github.com/openresty/headers-more-nginx-module/commits/master
69+
ARG VER_OPENRESTY_HEADERS=d6d7ebab3c0c5b32ab421ba186783d3e5d2c6a17
70+
ENV VER_OPENRESTY_HEADERS=$VER_OPENRESTY_HEADERS
71+
72+
# lua-resty-cookie
73+
# https://github.com/cloudflare/lua-resty-cookie/commits/master
74+
ARG VER_CLOUDFLARE_COOKIE=303e32e512defced053a6484bc0745cf9dc0d39e
75+
ENV VER_CLOUDFLARE_COOKIE=$VER_CLOUDFLARE_COOKIE
76+
77+
# lua-resty-dns
78+
# https://github.com/openresty/lua-resty-dns/releases
79+
ARG VER_OPENRESTY_DNS=0.21
80+
ENV VER_OPENRESTY_DNS=$VER_OPENRESTY_DNS
81+
82+
# lua-resty-memcached
83+
# https://github.com/openresty/lua-resty-memcached/releases
84+
ARG VER_OPENRESTY_MEMCACHED=0.15
85+
ENV VER_OPENRESTY_MEMCACHED=$VER_OPENRESTY_MEMCACHED
86+
87+
# lua-resty-mysql
88+
# https://github.com/openresty/lua-resty-mysql/releases
89+
ARG VER_OPENRESTY_MYSQL=0.22
90+
ENV VER_OPENRESTY_MYSQL=$VER_OPENRESTY_MYSQL
91+
92+
# lua-resty-redis
93+
# https://github.com/openresty/lua-resty-redis/releases
94+
ARG VER_OPENRESTY_REDIS=0.29
95+
ENV VER_OPENRESTY_REDIS=$VER_OPENRESTY_REDIS
96+
97+
# lua-resty-shell
98+
# https://github.com/openresty/lua-resty-shell/releases
99+
ARG VER_OPENRESTY_SHELL=0.03
100+
ENV VER_OPENRESTY_SHELL=$VER_OPENRESTY_SHELL
101+
102+
# lua-resty-upstream-healthcheck
103+
# https://github.com/openresty/lua-resty-upstream-healthcheck/releases
104+
ARG VER_OPENRESTY_HEALTHCHECK=0.06
105+
ENV VER_OPENRESTY_HEALTHCHECK=$VER_OPENRESTY_HEALTHCHECK
106+
107+
# lua-resty-websocket
108+
# https://github.com/openresty/lua-resty-websocket/releases
109+
ARG VER_OPENRESTY_WEBSOCKET=0.07
110+
ENV VER_OPENRESTY_WEBSOCKET=$VER_OPENRESTY_WEBSOCKET
111+
112+
# lua-upstream-nginx-module
113+
# https://github.com/openresty/lua-upstream-nginx-module/releases
114+
ARG VER_LUA_UPSTREAM=0.07
115+
ENV VER_LUA_UPSTREAM=$VER_LUA_UPSTREAM
116+
117+
# nginx-lua-prometheus
118+
# https://github.com/knyar/nginx-lua-prometheus/releases
119+
ARG VER_PROMETHEUS=0.20200523
120+
ENV VER_PROMETHEUS=$VER_PROMETHEUS
121+
122+
# stream-lua-nginx-module
123+
# https://github.com/openresty/stream-lua-nginx-module/releases
124+
ARG VER_OPENRESTY_STREAMLUA=0.0.8
125+
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126+
127+
# https://github.com/nginx/nginx/releases
128+
ARG VER_NGINX=1.19.5
129+
ENV VER_NGINX=$VER_NGINX
130+
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131+
ENV NGX_CFLAGS=$NGX_CFLAGS
132+
ARG NGX_LDOPT="-Wl,-rpath,/usr/local/lib -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie"
133+
ENV NGX_LDOPT=$NGX_LDOPT
134+
ARG NGINX_BUILD_CONFIG="\
135+
--prefix=/etc/nginx \
136+
--sbin-path=/usr/sbin/nginx \
137+
--modules-path=/usr/lib/nginx/modules \
138+
--conf-path=/etc/nginx/nginx.conf \
139+
--error-log-path=/var/log/nginx/error.log \
140+
--http-log-path=/var/log/nginx/access.log \
141+
--pid-path=/var/run/nginx.pid \
142+
--lock-path=/var/run/nginx.lock \
143+
--http-client-body-temp-path=/var/cache/nginx/client_temp \
144+
--http-proxy-temp-path=/var/cache/nginx/proxy_temp \
145+
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
146+
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
147+
--http-scgi-temp-path=/var/cache/nginx/scgi_temp \
148+
--with-perl_modules_path=/usr/lib/perl5/vendor_perl \
149+
--user=nginx \
150+
--group=nginx \
151+
--with-compat \
152+
--with-file-aio \
153+
--with-threads \
154+
--with-http_addition_module \
155+
--with-http_auth_request_module \
156+
--with-http_dav_module \
157+
--with-http_flv_module \
158+
--with-http_gunzip_module \
159+
--with-http_gzip_static_module \
160+
--with-http_mp4_module \
161+
--with-http_random_index_module \
162+
--with-http_realip_module \
163+
--with-http_secure_link_module \
164+
--with-http_slice_module \
165+
--with-http_ssl_module \
166+
--with-http_stub_status_module \
167+
--with-http_sub_module \
168+
--with-http_v2_module \
169+
--with-mail \
170+
--with-mail_ssl_module \
171+
--with-stream \
172+
--with-stream_realip_module \
173+
--with-stream_ssl_module \
174+
--with-stream_ssl_preread_module \
175+
--add-module=/lua-nginx-module-${VER_LUA_NGINX_MODULE} \
176+
--add-module=/ngx_devel_kit-${VER_NGX_DEVEL_KIT} \
177+
--add-module=/lua-upstream-nginx-module-${VER_LUA_UPSTREAM} \
178+
"
179+
ENV NGINX_BUILD_CONFIG=$NGINX_BUILD_CONFIG
180+
181+
ARG BUILD_DEPS="\
182+
GeoIP-devel \
183+
ca-certificates \
184+
gcc-c++ \
185+
gzip \
186+
make \
187+
openssl-devel \
188+
pcre-devel \
189+
tar \
190+
unzip \
191+
zlib-devel \
192+
"
193+
ENV BUILD_DEPS=$BUILD_DEPS
194+
195+
ARG NGINX_BUILD_DEPS=""
196+
ENV NGINX_BUILD_DEPS=$NGINX_BUILD_DEPS
197+
198+
####################################
199+
# Build Nginx with support for LUA #
200+
####################################
201+
FROM base AS builder
202+
203+
COPY tpl/Makefile Makefile
204+
205+
# TODO: NGINX_BUILD_CONFIG not updated
206+
# hadolint ignore=SC2086
207+
RUN set -eux \
208+
&& rpm --import https://src.fedoraproject.org/rpms/fedora-repos/raw/master/f/RPM-GPG-KEY-fedora-34-primary \
209+
&& dnf makecache \
210+
&& dnf install -y \
211+
$BUILD_DEPS \
212+
$NGINX_BUILD_DEPS \
213+
&& [ $EXTENDED_IMAGE -eq 1 ] && \
214+
NGINX_BUILD_CONFIG="${NGINX_BUILD_CONFIG} \
215+
--add-module=/headers-more-nginx-module-${VER_OPENRESTY_HEADERS} \
216+
--add-module=/stream-lua-nginx-module-${VER_OPENRESTY_STREAMLUA} \
217+
" \
218+
&& make -j "$(nproc)" deps \
219+
&& make -j "$(nproc)" core
220+
221+
RUN set -eux \
222+
# envsubst
223+
# ##############################################################################
224+
&& dnf makecache \
225+
&& dnf install -y \
226+
gettext
227+
228+
##########################################
229+
# Combine everything with minimal layers #
230+
##########################################
231+
FROM fedora:33
232+
233+
# http://label-schema.org/rc1/
234+
LABEL maintainer="Fabio Cicerchia <info@fabiocicerchia.it>" \
235+
org.label-schema.build-date=$BUILD_DATE \
236+
org.label-schema.description="Nginx $VER_NGINX with Lua support based on $DOCKER_IMAGE_OS $DOCKER_IMAGE_TAG." \
237+
org.label-schema.docker.cmd="docker run -p 80:80 -d $DOCKER_IMAGE:$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
238+
org.label-schema.name="$DOCKER_IMAGE" \
239+
org.label-schema.schema-version="1.0" \
240+
org.label-schema.url="https://github.com/$DOCKER_IMAGE" \
241+
org.label-schema.vcs-ref=$VCS_REF \
242+
org.label-schema.vcs-url="https://github.com/$DOCKER_IMAGE" \
243+
org.label-schema.version="$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
244+
versions.extended=${EXTENDED_IMAGE} \
245+
versions.headers-more-nginx-module=${VER_OPENRESTY_HEADERS} \
246+
versions.lua-nginx-module=${VER_LUA_NGINX_MODULE} \
247+
versions.lua-resty-cookie=${VER_CLOUDFLARE_COOKIE} \
248+
versions.lua-resty-core=${VER_LUA_RESTY_CORE} \
249+
versions.lua-resty-dns=${VER_OPENRESTY_DNS} \
250+
versions.lua-resty-lrucache=${VER_LUA_RESTY_LRUCACHE} \
251+
versions.lua-resty-memcached=${VER_OPENRESTY_MEMCACHED} \
252+
versions.lua-resty-mysql=${VER_OPENRESTY_MYSQL} \
253+
versions.lua-resty-redis=${VER_OPENRESTY_REDIS} \
254+
versions.lua-resty-shell=${VER_OPENRESTY_SHELL} \
255+
versions.lua-resty-upstream-healthcheck=${VER_OPENRESTY_HEALTHCHECK} \
256+
versions.lua-resty-websocket=${VER_OPENRESTY_WEBSOCKET} \
257+
versions.lua-upstream=${VER_LUA_UPSTREAM} \
258+
versions.luajit2=${VER_LUAJIT} \
259+
versions.nginx-lua-prometheus=${VER_PROMETHEUS} \
260+
versions.nginx=${VER_NGINX} \
261+
versions.ngx_devel_kit=${VER_NGX_DEVEL_KIT} \
262+
versions.os=${DOCKER_IMAGE_TAG} \
263+
versions.stream-lua-nginx-module=${VER_OPENRESTY_STREAMLUA}
264+
265+
ARG PKG_DEPS="\
266+
GeoIP-devel \
267+
ca-certificates \
268+
gcc-c++ \
269+
openssl-devel \
270+
pcre-devel \
271+
zlib-devel \
272+
"
273+
ENV PKG_DEPS=$PKG_DEPS
274+
275+
COPY --from=builder /etc/nginx /etc/nginx
276+
COPY --from=builder /usr/local/lib /usr/local/lib
277+
COPY --from=builder /usr/local/share/lua /usr/local/share/lua
278+
COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
279+
COPY --from=builder /usr/sbin/nginx-debug /usr/sbin/nginx-debug
280+
COPY --from=builder /var/cache/nginx /var/cache/nginx
281+
COPY --from=builder /usr/bin/envsubst /usr/local/bin/envsubst
282+
283+
SHELL ["/bin/sh", "-o", "pipefail", "-c"]
284+
285+
# hadolint ignore=SC2086
286+
RUN set -eux \
287+
&& rpm --import https://src.fedoraproject.org/rpms/fedora-repos/raw/master/f/RPM-GPG-KEY-fedora-34-primary \
288+
&& dnf makecache \
289+
&& dnf install -y \
290+
$PKG_DEPS \
291+
# Bring in tzdata so users could set the timezones through the environment
292+
# variables
293+
&& dnf install -y tzdata \
294+
# Bring in curl and ca-certificates to make registering on DNS SD easier
295+
&& dnf install -y curl ca-certificates \
296+
# forward request and error logs to docker log collector
297+
&& mkdir -p /var/log/nginx \
298+
&& ln -sf /dev/stdout /var/log/nginx/access.log \
299+
&& ln -sf /dev/stderr /var/log/nginx/error.log \
300+
# create nginx user/group first, to be consistent throughout docker variants
301+
&& groupadd --system --gid 101 nginx \
302+
&& useradd --system --gid nginx --no-create-home --home /nonexistent --comment "nginx user" --shell /bin/false --uid 101 nginx \
303+
&& mkdir /docker-entrypoint.d \
304+
# Cleanup
305+
# ##############################################################################
306+
&& dnf clean all \
307+
&& rm -rf /var/cache/dnf
308+
309+
COPY tpl/docker-entrypoint.sh /
310+
COPY tpl/10-listen-on-ipv6-by-default.sh /docker-entrypoint.d/
311+
COPY tpl/20-envsubst-on-templates.sh /docker-entrypoint.d/
312+
313+
# smoke test
314+
# ##############################################################################
315+
RUN envsubst -V \
316+
&& nginx -V \
317+
&& nginx -t
318+
319+
EXPOSE 80 443
320+
321+
HEALTHCHECK --interval=30s --timeout=3s CMD curl --fail http://localhost/ || exit 1
322+
323+
# Override stop signal to stop process gracefully
324+
STOPSIGNAL SIGQUIT
325+
326+
ENTRYPOINT ["/docker-entrypoint.sh"]
327+
328+
CMD ["nginx", "-g", "daemon off;"]

‎nginx/1.19.5/ubuntu/20.04/Dockerfile

+332
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,332 @@
1+
# __ __
2+
# .-----.-----.|__|.-----.--.--.______| |.--.--.---.-.
3+
# | | _ || || |_ _|______| || | | _ |
4+
# |__|__|___ ||__||__|__|__.__| |__||_____|___._|
5+
# |_____|
6+
#
7+
# Copyright (c) 2020 Fabio Cicerchia. https://fabiocicerchia.it. MIT License
8+
# Repo: https://github.com/fabiocicerchia/nginx-lua
9+
10+
FROM ubuntu:20.04 AS base
11+
12+
#############################
13+
# Settings Common Variables #
14+
#############################
15+
ARG DOCKER_IMAGE=fabiocicerchia/nginx-lua
16+
ENV DOCKER_IMAGE=$DOCKER_IMAGE
17+
ARG DOCKER_IMAGE_OS=ubuntu
18+
ENV DOCKER_IMAGE_OS=$DOCKER_IMAGE_OS
19+
ARG DOCKER_IMAGE_TAG=20.04
20+
ENV DOCKER_IMAGE_TAG=$DOCKER_IMAGE_TAG
21+
22+
ARG BUILD_DATE
23+
ENV BUILD_DATE=$BUILD_DATE
24+
ARG VCS_REF
25+
ENV VCS_REF=$VCS_REF
26+
27+
ARG EXTENDED_IMAGE=1
28+
ENV EXTENDED_IMAGE=$EXTENDED_IMAGE
29+
30+
# ngx_devel_kit
31+
# https://github.com/vision5/ngx_devel_kit/releases
32+
# The NDK is now considered to be stable.
33+
ARG VER_NGX_DEVEL_KIT=0.3.1
34+
ENV VER_NGX_DEVEL_KIT=$VER_NGX_DEVEL_KIT
35+
36+
# luajit2
37+
# https://github.com/openresty/luajit2/releases
38+
ARG VER_LUAJIT=2.1-20201012-2
39+
ENV VER_LUAJIT=$VER_LUAJIT
40+
ARG LUAJIT_LIB=/usr/local/lib
41+
ENV LUAJIT_LIB=$LUAJIT_LIB
42+
ARG LUAJIT_INC=/usr/local/include/luajit-2.1
43+
ENV LUAJIT_INC=$LUAJIT_INC
44+
ARG LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH
45+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH
46+
47+
# lua-nginx-module
48+
# https://github.com/openresty/lua-nginx-module/releases
49+
# Production ready.
50+
ARG VER_LUA_NGINX_MODULE=0.10.17
51+
ENV VER_LUA_NGINX_MODULE=$VER_LUA_NGINX_MODULE
52+
53+
# lua-resty-core
54+
# https://github.com/openresty/lua-resty-core/releases
55+
# This library is production ready.
56+
ARG VER_LUA_RESTY_CORE=0.1.19
57+
ENV VER_LUA_RESTY_CORE=$VER_LUA_RESTY_CORE
58+
ARG LUA_LIB_DIR=/usr/local/share/lua/5.1
59+
ENV LUA_LIB_DIR=$LUA_LIB_DIR
60+
61+
# lua-resty-lrucache
62+
# https://github.com/openresty/lua-resty-lrucache/releases
63+
# This library is considered production ready.
64+
ARG VER_LUA_RESTY_LRUCACHE=0.10
65+
ENV VER_LUA_RESTY_LRUCACHE=$VER_LUA_RESTY_LRUCACHE
66+
67+
# headers-more-nginx-module
68+
# https://github.com/openresty/headers-more-nginx-module/commits/master
69+
ARG VER_OPENRESTY_HEADERS=d6d7ebab3c0c5b32ab421ba186783d3e5d2c6a17
70+
ENV VER_OPENRESTY_HEADERS=$VER_OPENRESTY_HEADERS
71+
72+
# lua-resty-cookie
73+
# https://github.com/cloudflare/lua-resty-cookie/commits/master
74+
ARG VER_CLOUDFLARE_COOKIE=303e32e512defced053a6484bc0745cf9dc0d39e
75+
ENV VER_CLOUDFLARE_COOKIE=$VER_CLOUDFLARE_COOKIE
76+
77+
# lua-resty-dns
78+
# https://github.com/openresty/lua-resty-dns/releases
79+
ARG VER_OPENRESTY_DNS=0.21
80+
ENV VER_OPENRESTY_DNS=$VER_OPENRESTY_DNS
81+
82+
# lua-resty-memcached
83+
# https://github.com/openresty/lua-resty-memcached/releases
84+
ARG VER_OPENRESTY_MEMCACHED=0.15
85+
ENV VER_OPENRESTY_MEMCACHED=$VER_OPENRESTY_MEMCACHED
86+
87+
# lua-resty-mysql
88+
# https://github.com/openresty/lua-resty-mysql/releases
89+
ARG VER_OPENRESTY_MYSQL=0.22
90+
ENV VER_OPENRESTY_MYSQL=$VER_OPENRESTY_MYSQL
91+
92+
# lua-resty-redis
93+
# https://github.com/openresty/lua-resty-redis/releases
94+
ARG VER_OPENRESTY_REDIS=0.29
95+
ENV VER_OPENRESTY_REDIS=$VER_OPENRESTY_REDIS
96+
97+
# lua-resty-shell
98+
# https://github.com/openresty/lua-resty-shell/releases
99+
ARG VER_OPENRESTY_SHELL=0.03
100+
ENV VER_OPENRESTY_SHELL=$VER_OPENRESTY_SHELL
101+
102+
# lua-resty-upstream-healthcheck
103+
# https://github.com/openresty/lua-resty-upstream-healthcheck/releases
104+
ARG VER_OPENRESTY_HEALTHCHECK=0.06
105+
ENV VER_OPENRESTY_HEALTHCHECK=$VER_OPENRESTY_HEALTHCHECK
106+
107+
# lua-resty-websocket
108+
# https://github.com/openresty/lua-resty-websocket/releases
109+
ARG VER_OPENRESTY_WEBSOCKET=0.07
110+
ENV VER_OPENRESTY_WEBSOCKET=$VER_OPENRESTY_WEBSOCKET
111+
112+
# lua-upstream-nginx-module
113+
# https://github.com/openresty/lua-upstream-nginx-module/releases
114+
ARG VER_LUA_UPSTREAM=0.07
115+
ENV VER_LUA_UPSTREAM=$VER_LUA_UPSTREAM
116+
117+
# nginx-lua-prometheus
118+
# https://github.com/knyar/nginx-lua-prometheus/releases
119+
ARG VER_PROMETHEUS=0.20200523
120+
ENV VER_PROMETHEUS=$VER_PROMETHEUS
121+
122+
# stream-lua-nginx-module
123+
# https://github.com/openresty/stream-lua-nginx-module/releases
124+
ARG VER_OPENRESTY_STREAMLUA=0.0.8
125+
ENV VER_OPENRESTY_STREAMLUA=$VER_OPENRESTY_STREAMLUA
126+
127+
# https://github.com/nginx/nginx/releases
128+
ARG VER_NGINX=1.19.5
129+
ENV VER_NGINX=$VER_NGINX
130+
ARG NGX_CFLAGS="-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC"
131+
ENV NGX_CFLAGS=$NGX_CFLAGS
132+
ARG NGX_LDOPT="-Wl,-rpath,/usr/local/lib -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie"
133+
ENV NGX_LDOPT=$NGX_LDOPT
134+
ARG NGINX_BUILD_CONFIG="\
135+
--prefix=/etc/nginx \
136+
--sbin-path=/usr/sbin/nginx \
137+
--modules-path=/usr/lib/nginx/modules \
138+
--conf-path=/etc/nginx/nginx.conf \
139+
--error-log-path=/var/log/nginx/error.log \
140+
--http-log-path=/var/log/nginx/access.log \
141+
--pid-path=/var/run/nginx.pid \
142+
--lock-path=/var/run/nginx.lock \
143+
--http-client-body-temp-path=/var/cache/nginx/client_temp \
144+
--http-proxy-temp-path=/var/cache/nginx/proxy_temp \
145+
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
146+
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
147+
--http-scgi-temp-path=/var/cache/nginx/scgi_temp \
148+
--with-perl_modules_path=/usr/lib/perl5/vendor_perl \
149+
--user=nginx \
150+
--group=nginx \
151+
--with-compat \
152+
--with-file-aio \
153+
--with-threads \
154+
--with-http_addition_module \
155+
--with-http_auth_request_module \
156+
--with-http_dav_module \
157+
--with-http_flv_module \
158+
--with-http_gunzip_module \
159+
--with-http_gzip_static_module \
160+
--with-http_mp4_module \
161+
--with-http_random_index_module \
162+
--with-http_realip_module \
163+
--with-http_secure_link_module \
164+
--with-http_slice_module \
165+
--with-http_ssl_module \
166+
--with-http_stub_status_module \
167+
--with-http_sub_module \
168+
--with-http_v2_module \
169+
--with-mail \
170+
--with-mail_ssl_module \
171+
--with-stream \
172+
--with-stream_realip_module \
173+
--with-stream_ssl_module \
174+
--with-stream_ssl_preread_module \
175+
--add-module=/lua-nginx-module-${VER_LUA_NGINX_MODULE} \
176+
--add-module=/ngx_devel_kit-${VER_NGX_DEVEL_KIT} \
177+
--add-module=/lua-upstream-nginx-module-${VER_LUA_UPSTREAM} \
178+
"
179+
ENV NGINX_BUILD_CONFIG=$NGINX_BUILD_CONFIG
180+
181+
ARG BUILD_DEPS="\
182+
ca-certificates \
183+
curl \
184+
g++ \
185+
libgeoip-dev \
186+
libpcre3-dev \
187+
libssl-dev \
188+
make \
189+
unzip \
190+
zlib1g-dev \
191+
"
192+
ENV BUILD_DEPS=$BUILD_DEPS
193+
194+
ARG NGINX_BUILD_DEPS=""
195+
ENV NGINX_BUILD_DEPS=$NGINX_BUILD_DEPS
196+
197+
ENV DEBIAN_FRONTEND noninteractive
198+
199+
####################################
200+
# Build Nginx with support for LUA #
201+
####################################
202+
FROM base AS builder
203+
204+
COPY tpl/Makefile Makefile
205+
206+
# TODO: NGINX_BUILD_CONFIG not updated
207+
# hadolint ignore=SC2086
208+
RUN set -eux \
209+
&& apt-get update \
210+
&& apt-get install -y --no-install-recommends --no-install-suggests \
211+
apt-utils \
212+
&& apt-get install -y --no-install-recommends --no-install-suggests \
213+
$BUILD_DEPS \
214+
$NGINX_BUILD_DEPS \
215+
&& [ $EXTENDED_IMAGE -eq 1 ] && \
216+
NGINX_BUILD_CONFIG="${NGINX_BUILD_CONFIG} \
217+
--add-module=/headers-more-nginx-module-${VER_OPENRESTY_HEADERS} \
218+
--add-module=/stream-lua-nginx-module-${VER_OPENRESTY_STREAMLUA} \
219+
" \
220+
&& make -j "$(nproc)" deps \
221+
&& make -j "$(nproc)" core \
222+
&& rm -rf /var/lib/apt/lists/*
223+
224+
RUN set -eux \
225+
# envsubst
226+
# ##############################################################################
227+
&& apt-get update \
228+
&& apt-get install -y --no-install-recommends --no-install-suggests \
229+
gettext-base \
230+
&& rm -rf /var/lib/apt/lists/*
231+
232+
##########################################
233+
# Combine everything with minimal layers #
234+
##########################################
235+
FROM ubuntu:20.04
236+
237+
# http://label-schema.org/rc1/
238+
LABEL maintainer="Fabio Cicerchia <info@fabiocicerchia.it>" \
239+
org.label-schema.build-date=$BUILD_DATE \
240+
org.label-schema.description="Nginx $VER_NGINX with Lua support based on $DOCKER_IMAGE_OS $DOCKER_IMAGE_TAG." \
241+
org.label-schema.docker.cmd="docker run -p 80:80 -d $DOCKER_IMAGE:$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
242+
org.label-schema.name="$DOCKER_IMAGE" \
243+
org.label-schema.schema-version="1.0" \
244+
org.label-schema.url="https://github.com/$DOCKER_IMAGE" \
245+
org.label-schema.vcs-ref=$VCS_REF \
246+
org.label-schema.vcs-url="https://github.com/$DOCKER_IMAGE" \
247+
org.label-schema.version="$VER_NGINX-$DOCKER_IMAGE_OS$DOCKER_IMAGE_TAG" \
248+
versions.extended=${EXTENDED_IMAGE} \
249+
versions.headers-more-nginx-module=${VER_OPENRESTY_HEADERS} \
250+
versions.lua-nginx-module=${VER_LUA_NGINX_MODULE} \
251+
versions.lua-resty-cookie=${VER_CLOUDFLARE_COOKIE} \
252+
versions.lua-resty-core=${VER_LUA_RESTY_CORE} \
253+
versions.lua-resty-dns=${VER_OPENRESTY_DNS} \
254+
versions.lua-resty-lrucache=${VER_LUA_RESTY_LRUCACHE} \
255+
versions.lua-resty-memcached=${VER_OPENRESTY_MEMCACHED} \
256+
versions.lua-resty-mysql=${VER_OPENRESTY_MYSQL} \
257+
versions.lua-resty-redis=${VER_OPENRESTY_REDIS} \
258+
versions.lua-resty-shell=${VER_OPENRESTY_SHELL} \
259+
versions.lua-resty-upstream-healthcheck=${VER_OPENRESTY_HEALTHCHECK} \
260+
versions.lua-resty-websocket=${VER_OPENRESTY_WEBSOCKET} \
261+
versions.lua-upstream=${VER_LUA_UPSTREAM} \
262+
versions.luajit2=${VER_LUAJIT} \
263+
versions.nginx-lua-prometheus=${VER_PROMETHEUS} \
264+
versions.nginx=${VER_NGINX} \
265+
versions.ngx_devel_kit=${VER_NGX_DEVEL_KIT} \
266+
versions.os=${DOCKER_IMAGE_TAG} \
267+
versions.stream-lua-nginx-module=${VER_OPENRESTY_STREAMLUA}
268+
269+
ARG PKG_DEPS="\
270+
ca-certificates \
271+
libgeoip-dev \
272+
libpcre3-dev \
273+
libssl-dev \
274+
zlib1g-dev \
275+
"
276+
ENV PKG_DEPS=$PKG_DEPS
277+
278+
COPY --from=builder /etc/nginx /etc/nginx
279+
COPY --from=builder /usr/local/lib /usr/local/lib
280+
COPY --from=builder /usr/local/share/lua /usr/local/share/lua
281+
COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
282+
COPY --from=builder /usr/sbin/nginx-debug /usr/sbin/nginx-debug
283+
COPY --from=builder /var/cache/nginx /var/cache/nginx
284+
COPY --from=builder /usr/bin/envsubst /usr/local/bin/envsubst
285+
286+
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
287+
288+
ENV DEBIAN_FRONTEND noninteractive
289+
290+
# hadolint ignore=SC2086
291+
RUN set -eux \
292+
&& apt-get update \
293+
&& apt-get install -y --no-install-recommends --no-install-suggests \
294+
$PKG_DEPS \
295+
# Bring in tzdata so users could set the timezones through the environment
296+
# variables
297+
&& apt-get install -y --no-install-recommends --no-install-suggests tzdata \
298+
# Bring in curl and ca-certificates to make registering on DNS SD easier
299+
&& apt-get install -y --no-install-recommends --no-install-suggests curl ca-certificates \
300+
# forward request and error logs to docker log collector
301+
&& mkdir -p /var/log/nginx \
302+
&& ln -sf /dev/stdout /var/log/nginx/access.log \
303+
&& ln -sf /dev/stderr /var/log/nginx/error.log \
304+
# create nginx user/group first, to be consistent throughout docker variants
305+
&& addgroup --system --gid 101 nginx \
306+
&& adduser --system --disabled-login --ingroup nginx --no-create-home --home /nonexistent --gecos "nginx user" --shell /bin/false --uid 101 nginx \
307+
&& mkdir /docker-entrypoint.d \
308+
# Cleanup
309+
# ##############################################################################
310+
&& apt-get autoremove -y \
311+
&& rm -rf /var/lib/apt/lists/*
312+
313+
COPY tpl/docker-entrypoint.sh /
314+
COPY tpl/10-listen-on-ipv6-by-default.sh /docker-entrypoint.d/
315+
COPY tpl/20-envsubst-on-templates.sh /docker-entrypoint.d/
316+
317+
# smoke test
318+
# ##############################################################################
319+
RUN envsubst -V \
320+
&& nginx -V \
321+
&& nginx -t
322+
323+
EXPOSE 80 443
324+
325+
HEALTHCHECK --interval=30s --timeout=3s CMD curl --fail http://localhost/ || exit 1
326+
327+
# Override stop signal to stop process gracefully
328+
STOPSIGNAL SIGQUIT
329+
330+
ENTRYPOINT ["/docker-entrypoint.sh"]
331+
332+
CMD ["nginx", "-g", "daemon off;"]

‎supported_versions

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
NGINX=("1.19.4")
1+
NGINX=("1.19.5")
22
ALPINE=("3.12.1")
33
AMAZONLINUX=("2.0.20200722.0")
44
CENTOS=("8")

0 commit comments

Comments
 (0)
This repository has been archived.