Initial commit.
This commit is contained in:
commit
a1af12e076
31
Dockerfile
Normal file
31
Dockerfile
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#FROM container4armhf/armhf-alpine
|
||||||
|
FROM alpine
|
||||||
|
|
||||||
|
MAINTAINER Markus Birth <markus@birth-online.de>
|
||||||
|
|
||||||
|
LABEL description="Caddy HTTP/2 web server" \
|
||||||
|
version="1.0"
|
||||||
|
|
||||||
|
ENV AGREE_TOS="true" \
|
||||||
|
CADDY_ARCH="amd64" \
|
||||||
|
DEFAULT_EMAIL="changeme@example.com"
|
||||||
|
|
||||||
|
COPY ["caddy.d", "/data/caddy.d/"]
|
||||||
|
COPY ["compile_and_run.sh", "/usr/local/bin/"]
|
||||||
|
|
||||||
|
RUN apk add --update sed wget \
|
||||||
|
&& mkdir -p /data/caddy.d \
|
||||||
|
&& wget --no-check-certificate -q -O /tmp/caddy.tar.gz "https://caddyserver.com/download/build?os=linux&arch=${CADDY_ARCH}&features=" \
|
||||||
|
&& mkdir -p /opt/caddy \
|
||||||
|
&& cd /opt/caddy \
|
||||||
|
&& tar xzf /tmp/caddy.tar.gz \
|
||||||
|
&& rm /tmp/caddy.tar.gz \
|
||||||
|
&& chmod a+x /usr/local/bin/compile_and_run.sh \
|
||||||
|
&& apk del wget \
|
||||||
|
&& rm -rf /var/cache/*
|
||||||
|
|
||||||
|
VOLUME ["/data"]
|
||||||
|
|
||||||
|
EXPOSE 80 443
|
||||||
|
|
||||||
|
CMD ["/usr/local/bin/compile_and_run.sh"]
|
54
README.md
Normal file
54
README.md
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
Caddyserver Proxy
|
||||||
|
=================
|
||||||
|
|
||||||
|
This is a Docker image with a bare-bones [Caddyserver](https://caddyserver.com/).
|
||||||
|
|
||||||
|
It is meant to function as an SSL proxy to your intranet web services.
|
||||||
|
|
||||||
|
|
||||||
|
Caddyfiles
|
||||||
|
----------
|
||||||
|
|
||||||
|
Usually, Caddyserver only supports one single `Caddyfile` for configuration. This
|
||||||
|
Docker image contains a script which gathers all `*.caddy` files from the
|
||||||
|
`/data/caddy.d/` directory and concatenates them into one `Caddyfile` before
|
||||||
|
launching the server.
|
||||||
|
|
||||||
|
This way you can keep your configuration clean.
|
||||||
|
|
||||||
|
|
||||||
|
Example
|
||||||
|
-------
|
||||||
|
|
||||||
|
Here is a simple example to proxy my Subsonic via SSL:
|
||||||
|
|
||||||
|
```
|
||||||
|
subsonic.myhost.com {
|
||||||
|
proxy / http://homeserver:4040/ {
|
||||||
|
proxy_header Host subsonic.myhost.com
|
||||||
|
proxy_header Scheme https
|
||||||
|
# Enable if needed, e.g. for Wetty:
|
||||||
|
#websocket
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
This will accept HTTPS connections to subsonic.myhost.com on port 443 and
|
||||||
|
forward them to http://homeserver:4040/.
|
||||||
|
|
||||||
|
Make sure that each of your configured services has a unique hostname so
|
||||||
|
that Caddyserver can distinguish them.
|
||||||
|
|
||||||
|
|
||||||
|
Environment Variables
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
* `CADDY_ARCH` --- CPU architecture to use for Caddy, e.g. `386` or `arm`. Default: `amd64`
|
||||||
|
* `DEFAULT_EMAIL` --- The default email address to use for SSL certificate generation.
|
||||||
|
Can be overridden in Caddyfiles with the `tls` directive.
|
||||||
|
|
||||||
|
|
||||||
|
Volumes
|
||||||
|
-------
|
||||||
|
|
||||||
|
* `/data` --- holds the Caddyfiles and Logfile.
|
3
caddy.d/000-default.caddy
Normal file
3
caddy.d/000-default.caddy
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
:80 {
|
||||||
|
proxy / http://localhost:81/
|
||||||
|
}
|
6
compile_and_run.sh
Normal file
6
compile_and_run.sh
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
BASEPATH="/data"
|
||||||
|
# http://stackoverflow.com/questions/8183191/concatenating-files-and-insert-new-line-in-between-files
|
||||||
|
sed -e '$s/$/\n/' -s $BASEPATH/caddy.d/*.caddy > $BASEPATH/Caddyfile
|
||||||
|
|
||||||
|
exec /opt/caddy/caddy -agree=${AGREE_TOS} -email="${DEFAULT_EMAIL}" -conf="${BASEPATH}/Caddyfile" -log="${BASEPATH}/caddy.log"
|
Loading…
x
Reference in New Issue
Block a user