alpine
, (alpine/Dockerfile)alpine-fat
, (alpine-fat/Dockerfile)armhf-xenial
, (armhf-xenial/Dockerfile)centos
, (centos/Dockerfile)centos-rpm
, (centos-rpm/Dockerfile)jessie
, (jessie/Dockerfile)stretch
, (stretch/Dockerfile)trusty
, (trusty/Dockerfile)wheezy
, (wheezy/Dockerfile)xenial
, (xenial/Dockerfile)
- Description
- Usage
- OPM
- LuaRocks
- Docker ENTRYPOINT
- Building (from source)
- Building (RPM based)
- Building (DEB based)
- Feedback & Bug Reports
- Changelog
- Copyright & License
docker-openresty
is Docker tooling for OpenResty (https://www.openresty.org).
Docker is a container management platform.
OpenResty is a full-fledged web application server by bundling the standard nginx core, lots of 3rd-party nginx modules, as well as most of their external dependencies.
From non-RPM/DEB flavors, the following modules are included by default, but one can easily increase or decrease that with custom build options :
- file-aio
- http_addition_module
- http_auth_request_module
- http_dav_module
- http_flv_module
- http_geoip_module=dynamic
- http_gunzip_module
- http_gzip_static_module
- http_image_filter_module=dynamic
- http_mp4_module
- http_random_index_module
- http_realip_module
- http_secure_link_module
- http_slice_module
- http_ssl_module
- http_stub_status_module
- http_sub_module
- http_v2_module
- http_xslt_module=dynamic
- ipv6
- mail_ssl_module
- md5-asm
- pcre-jit
- sha1-asm
- stream
- stream_ssl_module
- threads
If you are happy with the build defaults, then you can use the openresty image from the Docker Hub. The image tags available there are listed at the top of this README.
docker run [options] openresty/openresty:trusty
[options] would be things like -p to map ports, -v to map volumes, and -d to daemonize.
docker-openresty
symlinks /usr/local/openresty/nginx/logs/access.log
and error.log
to /dev/stdout
and /dev/stderr
respectively, so that Docker logging works correctly. If you change the log paths in your nginx.conf
, you should symlink those paths as well.
Starting at version 1.11.2.2, OpenResty includes a package manager called opm
, which can be found at /usr/local/openresty/bin/opm
.
opm
is built in all the images except alpine
and stretch
.
To use opm
in the alpine
image, you must also install the perl
package; it is not included by default because it doubles the image size. You may install it like so: apk add --no-cache perl
.
To use opm
in the stretch
image, you must also install the openresty-opm
package as shown in this example.
LuaRocks is included in the alpine-fat
, centos
, centos-rpm
, trusty
, and xenial
variants. It is excluded from alpine
because it generally requires a build system and we want to keep that variant lean.
It is available at /usr/local/openresty/luajit/bin/luarocks
. Packages can be added in your dependent Dockerfiles like so:
RUN /usr/local/openresty/luajit/bin/luarocks install <rock>
The -g "daemon off;"
directive is used in the Dockerfile ENTRYPOINT to keep the Nginx daemon running after container creation. If this directive is added to the nginx.conf, then it may be omitted from the ENTRYPOINT.
To invoke with another ENTRYPOINT, for example the resty
utility, invoke like so:
docker run [options] --entrypoint /usr/local/openresty/bin/resty openresty/openresty:xenial [script.lua]
NOTE The alpine
images do not include the packages perl
and ncurses
, which is needed by the resty
utility.
This Docker image can be built and customized by cloning the repo and running docker build
with the desired Dockerfile:
git clone https://github.com/openresty/docker-openresty.git
cd docker-openresty
docker build -t myopenresty -f trusty/Dockerfile .
docker run myopenresty
Dockerfiles are provided for the following base systems, selecting the Dockerfile path with -f
:
- Alpine (
alpine/Dockerfile
) - Alpine Fat (
alpine-fat/Dockerfile
) - CentOS 7 (
centos/Dockerfile
) - Debian Jessie (
jessie/Dockerfile
) - Debian Wheezy (
wheezy/Dockerfile
) - Ubuntu Trusty (
trusty/Dockerfile
) - Ubuntu Xenial (
xenial/Dockerfile
) - Ubuntu Xenial armhf (
armhf-xenial/Dockerfile
)
The following are the available build-time options. They can be set using the --build-arg
CLI argument, like so:
docker build --build-arg RESTY_J=4 -f trusty/Dockerfile .
Key | Default | Description |
---|---|---|
RESTY_VERSION | 1.11.2.4 | The version of OpenResty to use. |
RESTY_LUAROCKS_VERSION | 2.3.0 | The version of LuaRocks to use. |
RESTY_OPENSSL_VERSION | 1.0.2k | The version of OpenSSL to use. |
RESTY_PCRE_VERSION | 8.39 | The version of PCRE to use. |
RESTY_J | 1 | Sets the parallelism level (-jN) for the builds. |
RESTY_CONFIG_OPTIONS | "--with-file-aio --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_flv_module --with-http_geoip_module=dynamic --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module=dynamic --with-http_mp4_module --with-http_perl_module=dynamic --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-http_xslt_module=dynamic --with-ipv6 --with-mail --with-mail_ssl_module --with-md5-asm --with-pcre-jit --with-sha1-asm --with-stream --with-stream_ssl_module --with-threads" | The options to pass to OpenResty's ./configure script. |
OpenResty now now has RPMs available. The centos-rpm
images use these RPMs rather than building from source.
This Docker image can be built and customized by cloning the repo and running docker build
with the desired Dockerfile:
- CentOS 7 RPM (
centos-rpm/Dockerfile
)
The following are the available build-time options. They can be set using the --build-arg
CLI argument, like so:
docker build --build-arg RESTY_RPM_FLAVOR="-debug" -f centos-rpm/Dockerfile centos-rpm
Key | Default | Description |
---|---|---|
RESTY_LUAROCKS_VERSION | 2.3.0 | The version of LuaRocks to use. |
RESTY_RPM_FLAVOR | "" | The openresty package flavor to use. Possibly "-debug" or "-valgrind" . |
RESTY_RPM_VERSION | 1.11.2.4-1.el7.centos.x86_64 | The openresty package version to install. |
OpenResty now now has Debian Packages (DEBs) available. The stretch
image use these DEBs rather than building from source.
You can derive your own Docker images from this to install your own packages. See Dockerfile.opm_example and Dockerfile.luarocks_example.
This Docker image can be built and customized by cloning the repo and running docker build
with the desired Dockerfile:
- Debian Stretch 9 DEB (
stretch/Dockerfile
)
The following are the available build-time options. They can be set using the --build-arg
CLI argument, like so:
docker build --build-arg RESTY_DEB_FLAVOR="-debug" -f stretch/Dockerfile stretch
Key | Default | Description |
---|---|---|
RESTY_DEB_FLAVOR | "" | The openresty package flavor to use. Possibly "-debug" or "-valgrind" . |
You're very welcome to report bugs and give feedback as GitHub Issues:
https://github.com/openresty/docker-openresty/issues
- Add
stretch
using official Debian packages
- Upgraded OpenResty to 1.11.2.4
- Update
centos-rpm
to 1.11.2.4-1
- Upgraded OpenResty to 1.11.2.3
- Upgraded OpenSSL to 1.0.2k
- Update
centos-rpm
to 1.11.2.3-1
- Change PCRE download URL to https://ftp.pcre.org/pub/pcre
- Add
armhf-xenial
image - Update
centos-rpm
to 1.11.2.2-8
- Add
alpine-fat
image - Remove 'latest' tags
- Upgraded OpenResty to 1.11.2.2
- Add resty-opm package to
centos-rpm
- Added Debian Jessie and Wheezy Builds
- Upgraded OpenSSL to 1.0.2j
- Upgraded OpenResty to 1.11.2.1
- Upgraded PCRE to 8.39
- Updated ENTRYPOINT to use the new symlink
/usr/local/openresty/bin/openresty
centos-rpm
now has the build argumentRESTY_RPM_VERSION
and ENTRYPOINT/usr/bin/openresty
- Upgraded OpenResty to 1.9.15.1
- Logging is redirected to /dev/stdout and /dev/stderr
- Introduced ENTRYPOINT with the
-g "daemon off;"
directive - Add
centos-rpm
base system, using upstream RPM packaging
docker-openresty is licensed under the 2-clause BSD license.
Copyright (c) 2017, Evan Wies [email protected].
This module is licensed under the terms of the BSD license.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.