# 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 " 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