diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 02:57:58 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 02:57:58 +0000 |
commit | be1c7e50e1e8809ea56f2c9d472eccd8ffd73a97 (patch) | |
tree | 9754ff1ca740f6346cf8483ec915d4054bc5da2d /Dockerfile.test | |
parent | Initial commit. (diff) | |
download | netdata-be1c7e50e1e8809ea56f2c9d472eccd8ffd73a97.tar.xz netdata-be1c7e50e1e8809ea56f2c9d472eccd8ffd73a97.zip |
Adding upstream version 1.44.3.upstream/1.44.3upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'Dockerfile.test')
-rw-r--r-- | Dockerfile.test | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/Dockerfile.test b/Dockerfile.test new file mode 100644 index 00000000..ef087d82 --- /dev/null +++ b/Dockerfile.test @@ -0,0 +1,74 @@ +# NOTE: This Dockerfile (`Dockerfile.test`) should only be used for dev/testing +# and *NOT* in production. Use the top-level `Dockerfile` which points to +# `./packaging/docker/Dockerfile`. +# +# TODO: Create a netdata/package-builder:alpine9 +#FROM netdata/package-builder:alpine AS build +FROM alpine:3.9 AS build + +# Install Dependencies +RUN apk add --no-cache -U alpine-sdk bash curl libuv-dev zlib-dev \ + util-linux-dev libmnl-dev gcc make git autoconf \ + automake pkgconfig python logrotate openssl-dev \ + cmake + +# Pass optional ./netdata-installer.sh args with --build-arg INSTALLER_ARGS=... +ARG INSTALLER_ARGS="" + +# Copy Sources +# Can also bind-mount sources with: +# $ docker run -v $PWD:/netdata + +WORKDIR /netdata +COPY . . + +# Build +RUN ./netdata-installer.sh --dont-wait --dont-start-it --disable-go "${INSTALLER_ARGS}" + +FROM alpine:3.9 AS runtime + +# Install runtime dependencies +RUN apk --no-cache -U add curl bash libuv zlib util-linux libmnl python + +# Create netdata user/group +RUN addgroup -S netdata && \ + adduser -D -S -h /var/empty -s /bin/false -G netdata netdata + +# Copy binary from build layer +COPY --from=build /usr/sbin/netdata /usr/sbin/netdata + +# Copy configuration files from build layer +COPY --from=build /etc/netdata/ /etc/netdata/ +COPY --from=build /usr/lib/netdata/ /usr/lib/netdata/ + +# Copy assets from build layer +COPY --from=build /usr/share/netdata/ /usr/share/netdata/ + +# Create some directories netdata needs +RUN mkdir -p \ + /etc/netdata \ + /var/log/netdata \ + /var/lib/netdata \ + /var/cache/netdata \ + /usr/lib/netdata/conf.d \ + /usr/libexec/netdata/plugins.d + +# Fix permissions/ownerships +RUN chown -R netdata:netdata \ + /etc/netdata/ \ + /usr/lib/netdata/ \ + /usr/share/netdata/ \ + /var/log/netdata \ + /var/lib/netdata \ + /var/cache/netdata \ + /usr/libexec/netdata + +VOLUME /etc/netdata +VOLUME /var/lib/netdata +VOLUME /var/log/netdata + +EXPOSE 19999/tcp + +USER netdata + +CMD ["/usr/sbin/netdata", "-D"] |