mirror of
https://github.com/netdata/netdata.git
synced 2024-11-21 15:28:05 +00:00
138 lines
5.1 KiB
Docker
138 lines
5.1 KiB
Docker
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
# author : paulfantom
|
|
|
|
# This image contains preinstalled dependencies
|
|
# hadolint ignore=DL3007
|
|
FROM netdata/builder:v2 AS builder
|
|
|
|
# One of 'nightly' or 'stable'
|
|
ARG RELEASE_CHANNEL=nightly
|
|
|
|
ARG CFLAGS
|
|
|
|
ENV CFLAGS=$CFLAGS
|
|
|
|
ARG EXTRA_INSTALL_OPTS
|
|
|
|
ENV EXTRA_INSTALL_OPTS=$EXTRA_INSTALL_OPTS
|
|
|
|
ARG DEBUG_BUILD
|
|
|
|
ENV DEBUG_BUILD=$DEBUG_BUILD
|
|
|
|
# Copy source
|
|
COPY . /opt/netdata.git
|
|
WORKDIR /opt/netdata.git
|
|
|
|
# Install from source
|
|
RUN chmod +x netdata-installer.sh && \
|
|
cp -rp /deps/* /usr/local/ && \
|
|
/bin/echo -e "INSTALL_TYPE='oci'\nPREBUILT_ARCH='$(uname -m)'" > ./system/.install-type && \
|
|
CFLAGS="$(packaging/docker/gen-cflags.sh)" LDFLAGS="-Wl,--gc-sections" ./netdata-installer.sh --dont-wait --dont-start-it --use-system-protobuf \
|
|
${EXTRA_INSTALL_OPTS} --disable-ebpf --install-no-prefix / "$([ "$RELEASE_CHANNEL" = stable ] && echo --stable-channel)"
|
|
|
|
# files to one directory
|
|
RUN mkdir -p /app/usr/sbin/ \
|
|
/app/usr/share \
|
|
/app/usr/libexec \
|
|
/app/usr/local \
|
|
/app/usr/lib \
|
|
/app/var/cache \
|
|
/app/var/lib \
|
|
/app/etc && \
|
|
mv /usr/share/netdata /app/usr/share/ && \
|
|
mv /usr/libexec/netdata /app/usr/libexec/ && \
|
|
mv /usr/lib/netdata /app/usr/lib/ && \
|
|
mv /var/cache/netdata /app/var/cache/ && \
|
|
mv /var/lib/netdata /app/var/lib/ && \
|
|
mv /etc/netdata /app/etc/ && \
|
|
mv /usr/sbin/netdata /app/usr/sbin/ && \
|
|
mv /usr/sbin/netdatacli /app/usr/sbin/ && \
|
|
mv /usr/sbin/systemd-cat-native /app/usr/sbin/ && \
|
|
mv packaging/docker/run.sh /app/usr/sbin/ && \
|
|
mv packaging/docker/health.sh /app/usr/sbin/ && \
|
|
mkdir -p /deps/etc && \
|
|
cp -rp /deps/etc /app/usr/local/etc && \
|
|
chmod -R o+rX /app && \
|
|
chmod +x /app/usr/sbin/run.sh
|
|
|
|
#####################################################################
|
|
# This image contains preinstalled dependencies
|
|
# hadolint ignore=DL3007
|
|
FROM netdata/base:v2 AS base
|
|
|
|
LABEL org.opencontainers.image.authors="Netdatabot <bot@netdata.cloud>"
|
|
LABEL org.opencontainers.image.url="https://netdata.cloud"
|
|
LABEL org.opencontainers.image.documentation="https://learn.netdata.cloud"
|
|
LABEL org.opencontainers.image.source="https://github.com/netdata/netdata"
|
|
LABEL org.opencontainers.image.title="Netdata Agent"
|
|
LABEL org.opencontainers.image.description="Official Netdata Agent Docker Image"
|
|
LABEL org.opencontainers.image.vendor="Netdata Inc."
|
|
|
|
ARG OFFICIAL_IMAGE=false
|
|
ENV NETDATA_OFFICIAL_IMAGE=$OFFICIAL_IMAGE
|
|
|
|
ONBUILD ENV NETDATA_OFFICIAL_IMAGE=false
|
|
|
|
ARG NETDATA_UID=201
|
|
ARG NETDATA_GID=201
|
|
ENV DOCKER_GRP=netdata
|
|
ENV DOCKER_USR=netdata
|
|
# If DISABLE_TELEMETRY is set, it will disable anonymous stats collection and reporting
|
|
#ENV DISABLE_TELEMETRY=1
|
|
ENV NETDATA_LISTENER_PORT=19999
|
|
EXPOSE $NETDATA_LISTENER_PORT
|
|
|
|
ENV NETDATA_EXTRA_DEB_PACKAGES=""
|
|
|
|
RUN mkdir -p /opt/src /var/log/netdata && \
|
|
ln -sf /dev/stdout /var/log/netdata/access.log && \
|
|
ln -sf /dev/stdout /var/log/netdata/aclk.log && \
|
|
ln -sf /dev/stdout /var/log/netdata/debug.log && \
|
|
ln -sf /dev/stderr /var/log/netdata/error.log && \
|
|
ln -sf /dev/stderr /var/log/netdata/daemon.log && \
|
|
ln -sf /dev/stdout /var/log/netdata/collector.log && \
|
|
ln -sf /dev/stdout /var/log/netdata/fluentbit.log && \
|
|
ln -sf /dev/stdout /var/log/netdata/health.log
|
|
|
|
COPY --from=builder /app /
|
|
|
|
# Create netdata user and apply the permissions as described in
|
|
# https://docs.netdata.cloud/docs/netdata-security/#netdata-directories, but own everything by root group due to https://github.com/netdata/netdata/pull/6543
|
|
# hadolint ignore=DL3013
|
|
RUN addgroup --gid ${NETDATA_GID} --system "${DOCKER_GRP}" && \
|
|
adduser --system --no-create-home --shell /usr/sbin/nologin --uid ${NETDATA_UID} --home /etc/netdata --group "${DOCKER_USR}" && \
|
|
chown -R root:root \
|
|
/etc/netdata \
|
|
/usr/share/netdata \
|
|
/usr/libexec/netdata && \
|
|
chown -R netdata:root \
|
|
/usr/lib/netdata \
|
|
/var/cache/netdata \
|
|
/var/lib/netdata \
|
|
/var/log/netdata && \
|
|
chown -R netdata:netdata /var/lib/netdata/cloud.d && \
|
|
chmod 0700 /var/lib/netdata/cloud.d && \
|
|
chmod 0755 /usr/libexec/netdata/plugins.d/*.plugin && \
|
|
for name in cgroup-network \
|
|
local-listeners \
|
|
apps.plugin \
|
|
debugfs.plugin \
|
|
freeipmi.plugin \
|
|
go.d.plugin \
|
|
perf.plugin \
|
|
ndsudo \
|
|
slabinfo.plugin \
|
|
network-viewer.plugin \
|
|
systemd-journal.plugin; do \
|
|
[ -f "/usr/libexec/netdata/plugins.d/$name" ] && chmod 4755 "/usr/libexec/netdata/plugins.d/$name"; \
|
|
done && \
|
|
# Group write permissions due to: https://github.com/netdata/netdata/pull/6543
|
|
find /var/lib/netdata /var/cache/netdata -type d -exec chmod 0770 {} \; && \
|
|
find /var/lib/netdata /var/cache/netdata -type f -exec chmod 0660 {} \; && \
|
|
cp -va /etc/netdata /etc/netdata.stock
|
|
|
|
ENTRYPOINT ["/usr/sbin/run.sh"]
|
|
|
|
HEALTHCHECK --interval=60s --timeout=10s --retries=3 CMD /usr/sbin/health.sh
|