Dockerfile 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. # SPDX-License-Identifier: GPL-3.0-or-later
  2. # author : paulfantom
  3. # This image contains preinstalled dependencies
  4. # hadolint ignore=DL3007
  5. FROM netdata/builder:latest as builder
  6. # One of 'nightly' or 'stable'
  7. ARG RELEASE_CHANNEL=nightly
  8. ENV JUDY_VER 1.0.5
  9. ARG CFLAGS
  10. ENV CFLAGS=$CFLAGS
  11. ARG EXTRA_INSTALL_OPTS
  12. ENV EXTRA_INSTALL_OPTS=$EXTRA_INSTALL_OPTS
  13. # Copy source
  14. COPY . /opt/netdata.git
  15. WORKDIR /opt/netdata.git
  16. # Install from source
  17. RUN chmod +x netdata-installer.sh && \
  18. cp -rp /deps/* /usr/local/ && \
  19. /bin/echo -e "INSTALL_TYPE='oci'\nPREBUILT_ARCH='$(uname -m)'" > ./system/.install-type && \
  20. ./netdata-installer.sh --dont-wait --dont-start-it --use-system-protobuf ${EXTRA_INSTALL_OPTS} \
  21. "$([ "$RELEASE_CHANNEL" = stable ] && echo --stable-channel)"
  22. # files to one directory
  23. RUN mkdir -p /app/usr/sbin/ \
  24. /app/usr/share \
  25. /app/usr/libexec \
  26. /app/usr/local \
  27. /app/usr/lib \
  28. /app/var/cache \
  29. /app/var/lib \
  30. /app/etc && \
  31. mv /usr/share/netdata /app/usr/share/ && \
  32. mv /usr/libexec/netdata /app/usr/libexec/ && \
  33. mv /usr/lib/netdata /app/usr/lib/ && \
  34. mv /var/cache/netdata /app/var/cache/ && \
  35. mv /var/lib/netdata /app/var/lib/ && \
  36. mv /etc/netdata /app/etc/ && \
  37. mv /usr/sbin/netdata /app/usr/sbin/ && \
  38. mv /usr/sbin/netdata-claim.sh /app/usr/sbin/ && \
  39. mv /usr/sbin/netdatacli /app/usr/sbin/ && \
  40. mv packaging/docker/run.sh /app/usr/sbin/ && \
  41. mv packaging/docker/health.sh /app/usr/sbin/ && \
  42. cp -rp /deps/* /app/usr/local/ && \
  43. chmod +x /app/usr/sbin/run.sh
  44. #####################################################################
  45. # This image contains preinstalled dependencies
  46. # hadolint ignore=DL3007
  47. FROM netdata/base:latest as base
  48. ARG OFFICIAL_IMAGE=false
  49. ENV NETDATA_OFFICIAL_IMAGE=$OFFICIAL_IMAGE
  50. # Configure system
  51. ARG NETDATA_UID=201
  52. ARG NETDATA_GID=201
  53. ENV DOCKER_GRP netdata
  54. ENV DOCKER_USR netdata
  55. # If DISABLE_TELEMETRY is set, it will disable anonymous stats collection and reporting
  56. #ENV DISABLE_TELEMETRY=1
  57. # Copy files over
  58. RUN mkdir -p /opt/src /var/log/netdata && \
  59. # Link log files to stdout
  60. ln -sf /dev/stdout /var/log/netdata/access.log && \
  61. ln -sf /dev/stdout /var/log/netdata/debug.log && \
  62. ln -sf /dev/stderr /var/log/netdata/error.log && \
  63. # fping from alpine apk is on a different location. Moving it.
  64. ln -snf /usr/sbin/fping /usr/local/bin/fping && \
  65. chmod 4755 /usr/local/bin/fping && \
  66. # Add netdata user
  67. addgroup -g ${NETDATA_GID} -S "${DOCKER_GRP}" && \
  68. adduser -S -H -s /usr/sbin/nologin -u ${NETDATA_GID} -h /etc/netdata -G "${DOCKER_GRP}" "${DOCKER_USR}"
  69. # Fix handling of config directory
  70. # Long-term this should leverage BuildKit’s mount option.
  71. COPY --from=builder /wheels /wheels
  72. COPY --from=builder /app /
  73. # Apply the permissions as described in
  74. # https://docs.netdata.cloud/docs/netdata-security/#netdata-directories, but own everything by root group due to https://github.com/netdata/netdata/pull/6543
  75. # hadolint ignore=DL3013
  76. RUN chown -R root:root \
  77. /etc/netdata \
  78. /usr/share/netdata \
  79. /usr/libexec/netdata && \
  80. chown -R netdata:root \
  81. /usr/lib/netdata \
  82. /var/cache/netdata \
  83. /var/lib/netdata \
  84. /var/log/netdata && \
  85. chown -R netdata:netdata /var/lib/netdata/cloud.d && \
  86. chmod 0700 /var/lib/netdata/cloud.d && \
  87. chmod 0755 /usr/libexec/netdata/plugins.d/*.plugin && \
  88. chmod 4755 \
  89. /usr/libexec/netdata/plugins.d/cgroup-network \
  90. /usr/libexec/netdata/plugins.d/apps.plugin && \
  91. if [ -f /usr/libexec/netdata/plugins.d/freeipmi.plugin ]; then \
  92. chmod 4755 /usr/libexec/netdata/plugins.d/freeipmi.plugin; \
  93. fi && \
  94. # Group write permissions due to: https://github.com/netdata/netdata/pull/6543
  95. find /var/lib/netdata /var/cache/netdata -type d -exec chmod 0770 {} \; && \
  96. find /var/lib/netdata /var/cache/netdata -type f -exec chmod 0660 {} \; && \
  97. pip --no-cache-dir install /wheels/* && \
  98. rm -rf /wheels && \
  99. cp -va /etc/netdata /etc/netdata.stock
  100. ENV NETDATA_LISTENER_PORT 19999
  101. EXPOSE $NETDATA_LISTENER_PORT
  102. ENTRYPOINT ["/usr/sbin/run.sh"]
  103. HEALTHCHECK --interval=60s --timeout=10s --retries=3 CMD /usr/sbin/health.sh
  104. ONBUILD ENV NETDATA_OFFICIAL_IMAGE=false