-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile
109 lines (91 loc) · 5.42 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
# I am pulling in my alpine-s6 image as the base here so I can reuse it for the common buildimage and later in the runtime.
# Initially I used to pull this separately at each stage but that gave errors with docker buildx for the BASE_VERSION argument.
ARG BASE_VERSION=3.13-2.2.0.3
FROM rakheshster/alpine-s6:${BASE_VERSION} AS mybase
################################### COMMON BUILDIMAGE ####################################
# This image is to be a base where all the build dependencies are installed.
# I can use this in the subsequent stages to build stuff
FROM mybase AS builder1
# I realized that the build process doesn't remove this intermediate image automatically so best to LABEL it here and then prune later
# Thanks to https://stackoverflow.com/a/55082473
LABEL stage="builder1"
LABEL maintainer="Rakhesh Sasidharan"
ENV UNBOUND_VERSION 1.13.0
ENV GETDNS_VERSION 1.6.0
ENV STUBBY_VERSION 0.3.0
# Get the build-dependencies for everything I plan on building later
# common stuff: git build-base libtool xz cmake gnupg (to verify)
# stubby/ getdns: (https://github.com/getdnsapi/getdns#external-dependencies) openssl-dev yaml-dev
# unbound: expat-dev
RUN apk add --update --no-cache \
git build-base libtool xz cmake gnupg \
openssl-dev yaml-dev libidn2-dev libuv-dev libev-dev check-dev \
expat-dev
RUN rm -rf /var/cache/apk/*
################################### UNBOUND ####################################
# Download the source & build it
# Get the Unbound source and key
ADD https://nlnetlabs.nl/downloads/unbound/unbound-${UNBOUND_VERSION}.tar.gz /tmp/
ADD https://www.nlnetlabs.nl/downloads/unbound/unbound-${UNBOUND_VERSION}.tar.gz.asc /tmp/
# Import NLNetLabs's key (W.C.A. Wijngaards <wouter@nlnetlabs.nl>)
RUN gpg --recv-keys 0x9F6F1C2D7E045F8D
# Verify the download (exit if it fails)
RUN gpg --status-fd 1 --verify /tmp/unbound-${UNBOUND_VERSION}.tar.gz.asc /tmp/unbound-${UNBOUND_VERSION}.tar.gz 2>/dev/null | grep -q "GOODSIG 9F6F1C2D7E045F8D" \
|| exit 1
WORKDIR /src
RUN tar xzf /tmp/unbound-${UNBOUND_VERSION}.tar.gz -C ./
WORKDIR /src/unbound-${UNBOUND_VERSION}
# Configure to expect everything in / (--prefix=/) but when installing put everything into /usr/local (via DESTDIR=)
# In the final stage I copy the contents of this to / so that's why I do it this way. Just copy everything in /usr/local out of this stage
RUN ./configure --prefix=/
RUN make && DESTDIR=/usr/local make install
################################### STUBBY ####################################
# I continue with the previous stage as Stubby needs Unbound libraries.
# Download the source & build it
# Official recommendation (for example: https://github.com/getdnsapi/getdns/releases/tag/v1.6.0) is to get the tarball from getdns than from GitHub
# Stubby is developed by the getdns team. When building getdns one can also build stubby alongwith
# libgetdns is a dependancy for Stubby, the getdns library provides all the core functionality for DNS resolution done by Stubby so it is important to build against the latest version of getdns.
ADD https://getdnsapi.net/dist/getdns-${GETDNS_VERSION}.tar.gz /tmp/
ADD https://getdnsapi.net/dist/getdns-${GETDNS_VERSION}.tar.gz.asc /tmp/
# Import GetDNS's key (Willem Toorop <willem@nlnetlabs.nl>)
RUN gpg --recv-keys 0xE5F8F8212F77A498
# Verify the download (exit if it fails)
RUN gpg --status-fd 1 --verify /tmp/getdns-${GETDNS_VERSION}.tar.gz.asc /tmp/getdns-${GETDNS_VERSION}.tar.gz 2>/dev/null | grep -q "GOODSIG E5F8F8212F77A498" \
|| exit 1
# Create a workdir called /src, extract the getdns source to that, build it
# Cmake steps from https://lektor.getdnsapi.net/quick-start/cmake-quick-start/ (v 1.6.0)
WORKDIR /src
RUN tar xzf /tmp/getdns-${GETDNS_VERSION}.tar.gz -C ./
WORKDIR /src/getdns-${GETDNS_VERSION}/build
# Same as above, set the path to / and install to /usr/local
RUN cmake -DBUILD_STUBBY=ON -DCMAKE_INSTALL_PREFIX:PATH=/ ..
RUN make && DESTDIR=/usr/local make install
################################### RUNTIME ENVIRONMENT FOR UNBOUND & STUBBY ####################################
FROM mybase AS finalstage
LABEL maintainer="Rakhesh Sasidharan"
LABEL org.opencontainers.image.source=https://github.com/rakheshster/docker-stubby-unbound
# Get the runtimes deps for all
# stubby (found via running it): yaml libidn2 openssl (not required but I am adding it for troubleshooting)
RUN apk add --update --no-cache ca-certificates tzdata \
yaml libidn2 openssl \
drill nano
RUN rm -rf /var/cache/apk/*
# Copy the Stubby & Unbound files from the previous builds into this
# /usr/local/bin -> /bin etc.
COPY --from=builder1 /usr/local/ /
# Copy the config files & s6 service files to the correct location
COPY root/ /
# Get root hints for Unbound
ADD https://www.internic.net/domain/named.cache /etc/unbound/root.hints
# addgroup / adduser -S creates a system group / user; the -D means don't assign a password
RUN addgroup -S unbound && adduser -D -S unbound -G unbound
RUN addgroup -S stubby && adduser -D -S stubby -G stubby
RUN mkdir -p /var/cache/stubby
RUN chown stubby:stubby /var/cache/stubby
RUN chown unbound:unbound /etc/unbound/root.hints
# NOTE: s6 overlay doesn't support running as a different user, but I set the stubby service to run under user "stubby" in its service definition.
# Similarly Unbound runs under its own user & group via the config file.
EXPOSE 8053/udp 53/udp 53/tcp
HEALTHCHECK --interval=5s --timeout=3s --start-period=5s \
CMD drill @127.0.0.1 -p 8053 google.com || exit 1
ENTRYPOINT ["/init"]