# SPDX-License-Identifier: GPL-3.0-or-later # author : paulfantom # Cross-arch building is achieved by specifying ARCH as a build parameter with `--build-arg` option. # It is automated in `build.sh` script ARG ARCH=amd64 # This image contains preinstalled dependecies FROM netdata/builder:${ARCH} as builder # One of 'nightly' or 'stable' ARG RELEASE_CHANNEL=nightly ENV JUDY_VER 1.0.5 ARG CFLAGS ENV CFLAGS=$CFLAGS ARG EXTRA_INSTALL_OPTS ENV EXTRA_INSTALL_OPTS=$EXTRA_INSTALL_OPTS # Copy source COPY . /opt/netdata.git WORKDIR /opt/netdata.git # Install from source RUN chmod +x netdata-installer.sh && \ cp -rp /deps/* /usr/local/ && \ ./netdata-installer.sh --dont-wait --dont-start-it ${EXTRA_INSTALL_OPTS} \ $([ "$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/netdata-claim.sh /app/usr/sbin/ && \ mv /usr/sbin/netdatacli /app/usr/sbin/ && \ mv packaging/docker/run.sh /app/usr/sbin/ && \ cp -rp /deps/* /app/usr/local/ && \ chmod +x /app/usr/sbin/run.sh ##################################################################### ARG ARCH # This image contains preinstalled dependecies FROM netdata/base:${ARCH} # Copy files over RUN mkdir -p /opt/src COPY --from=builder /app / COPY --from=builder /wheels /wheels COPY packaging/docker/health.sh /health.sh # Configure system ARG NETDATA_UID=201 ARG NETDATA_GID=201 ENV DOCKER_GRP netdata ENV DOCKER_USR netdata # If DO_NOT_TRACK is set, it will disable anonymous stats collection and reporting #ENV DO_NOT_TRACK=1 RUN \ # fping from alpine apk is on a different location. Moving it. mv /usr/sbin/fping /usr/local/bin/fping && \ chmod 4755 /usr/local/bin/fping && \ mkdir -p /var/log/netdata && \ # Add netdata user addgroup -g ${NETDATA_GID} -S "${DOCKER_GRP}" && \ adduser -S -H -s /usr/sbin/nologin -u ${NETDATA_GID} -h /etc/netdata -G "${DOCKER_GRP}" "${DOCKER_USR}" && \ # 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 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 && \ chmod 4755 \ /usr/libexec/netdata/plugins.d/cgroup-network \ /usr/libexec/netdata/plugins.d/apps.plugin \ /usr/libexec/netdata/plugins.d/freeipmi.plugin && \ # 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 {} \; && \ # Link log files to stdout ln -sf /dev/stdout /var/log/netdata/access.log && \ ln -sf /dev/stdout /var/log/netdata/debug.log && \ ln -sf /dev/stderr /var/log/netdata/error.log # Install any Python wheels RUN pip install /wheels/* ENV NETDATA_PORT 19999 EXPOSE $NETDATA_PORT ENTRYPOINT ["/usr/sbin/run.sh"] HEALTHCHECK --interval=60s --timeout=10s --retries=3 CMD /health.sh