Package: guix-patches;
Reported by: Léo Le Bouter <lle-bout <at> zaclys.net>
Date: Thu, 11 Feb 2021 08:11:02 UTC
Severity: normal
Tags: patch
To reply to this bug, email your comments to 46435 AT debbugs.gnu.org.
Toggle the display of automated, internal messages from the tracker.
View this report as an mbox folder, status mbox, maintainer mbox
guix-patches <at> gnu.org
:bug#46435
; Package guix-patches
.
(Thu, 11 Feb 2021 08:11:02 GMT) Full text and rfc822 format available.Léo Le Bouter <lle-bout <at> zaclys.net>
:guix-patches <at> gnu.org
.
(Thu, 11 Feb 2021 08:11:02 GMT) Full text and rfc822 format available.Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
From: Léo Le Bouter <lle-bout <at> zaclys.net> To: guix-patches <at> gnu.org Cc: Léo Le Bouter <lle-bout <at> zaclys.net> Subject: [PATCH] gnu: Add netdata. Date: Thu, 11 Feb 2021 09:09:44 +0100
* gnu/packages/monitoring.scm (netdata): New variable. * gnu/packages/patches/netdata-0001-use-system-python.patch, gnu/packages/patches/netdata-0002-use-system-exim4.patch, gnu/packages/patches/netdata-0003-use-python3.patch, gnu/packages/patches/netdata-0004-use-sh.patch, gnu/packages/patches/netdata-0005-use-bash.patch, gnu/packages/patches/netdata-no-files-in-etc-and-var.patch, gnu/packages/patches/netdata-web-remove-antifeatures-spyware.patch: New patches. * gnu/local.mk (dist_patch_DATA): Register them. --- gnu/local.mk | 7 + gnu/packages/monitoring.scm | 106 + .../netdata-0001-use-system-python.patch | 131 + .../netdata-0002-use-system-exim4.patch | 12 + .../patches/netdata-0003-use-python3.patch | 29 + .../patches/netdata-0004-use-sh.patch | 12 + .../patches/netdata-0005-use-bash.patch | 13 + .../netdata-no-files-in-etc-and-var.patch | 129 + ...data-web-remove-antifeatures-spyware.patch | 4466 +++++++++++++++++ 9 files changed, 4905 insertions(+) create mode 100644 gnu/packages/patches/netdata-0001-use-system-python.patch create mode 100644 gnu/packages/patches/netdata-0002-use-system-exim4.patch create mode 100644 gnu/packages/patches/netdata-0003-use-python3.patch create mode 100644 gnu/packages/patches/netdata-0004-use-sh.patch create mode 100644 gnu/packages/patches/netdata-0005-use-bash.patch create mode 100644 gnu/packages/patches/netdata-no-files-in-etc-and-var.patch create mode 100644 gnu/packages/patches/netdata-web-remove-antifeatures-spyware.patch diff --git a/gnu/local.mk b/gnu/local.mk index 8a31bfef64..8d1e6a6fa5 100644 --- a/gnu/local.mk +++ b/gnu/local.mk @@ -1388,6 +1388,13 @@ dist_patch_DATA = \ %D%/packages/patches/m4-gnulib-libio.patch \ %D%/packages/patches/ncompress-fix-softlinks.patch \ %D%/packages/patches/netcdf-date-time.patch \ + %D%/packages/patches/netdata-0001-use-system-python.patch \ + %D%/packages/patches/netdata-0002-use-system-exim4.patch \ + %D%/packages/patches/netdata-0003-use-python3.patch \ + %D%/packages/patches/netdata-0004-use-sh.patch \ + %D%/packages/patches/netdata-0005-use-bash.patch \ + %D%/packages/patches/netdata-no-files-in-etc-and-var.patch \ + %D%/packages/patches/netdata-web-remove-antifeatures-spyware.patch %D%/packages/patches/netpbm-CVE-2017-2586.patch \ %D%/packages/patches/netpbm-CVE-2017-2587.patch \ %D%/packages/patches/netsurf-message-timestamp.patch \ diff --git a/gnu/packages/monitoring.scm b/gnu/packages/monitoring.scm index 75a422921c..b0673c8321 100644 --- a/gnu/packages/monitoring.scm +++ b/gnu/packages/monitoring.scm @@ -41,24 +41,31 @@ #:use-module (gnu packages curl) #:use-module (gnu packages check) #:use-module (gnu packages compression) + #:use-module (gnu packages cups) #:use-module (gnu packages databases) + #:use-module (gnu packages disk) #:use-module (gnu packages django) + #:use-module (gnu packages gawk) #:use-module (gnu packages gd) #:use-module (gnu packages gettext) #:use-module (gnu packages image) #:use-module (gnu packages mail) #:use-module (gnu packages ncurses) #:use-module (gnu packages networking) + #:use-module (gnu packages node) #:use-module (gnu packages libevent) + #:use-module (gnu packages linux) #:use-module (gnu packages pcre) #:use-module (gnu packages perl) #:use-module (gnu packages pkg-config) + #:use-module (gnu packages protobuf) #:use-module (gnu packages python) #:use-module (gnu packages python-web) #:use-module (gnu packages python-xyz) #:use-module (gnu packages rrdtool) #:use-module (gnu packages time) #:use-module (gnu packages tls) + #:use-module (gnu packages version-control) #:use-module (gnu packages web)) (define-public nagios @@ -575,3 +582,102 @@ future system load (i.e., capacity planning).") ;; license:gpl2 for other plugins (license (list license:expat license:gpl2)))) +(define-public netdata + ;; TODO: Support go plugins, if not more. + (package + (name "netdata") + (version "1.29.1") + (source (origin + (method git-fetch) + (uri (git-reference + (url "https://github.com/netdata/netdata") + (commit (string-append "v" version)))) + (file-name (git-file-name name version)) + (sha256 + (base32 + "137qx7m9h2qk1pcy3i8rf7yk744zi7ps3867psy2r45l7k3flrss")) + (patches + (search-patches + ;; Remove Google Analytics, Google Tag Manager, update popups, + ;; global default registry and Netdata Cloud support (nonfree + ;; service). + "netdata-web-remove-antifeatures-spyware.patch" + ;; From Nix + "netdata-no-files-in-etc-and-var.patch" + ;; From Debian + "netdata-0001-use-system-python.patch" + "netdata-0002-use-system-exim4.patch" + "netdata-0003-use-python3.patch" + "netdata-0004-use-sh.patch" + "netdata-0005-use-bash.patch")))) + (build-system gnu-build-system) + (arguments + `(#:configure-flags (list "--localstatedir=/var" + "--sysconfdir=/etc" + "--disable-cloud") + #:phases + (modify-phases %standard-phases + (add-after 'install 'wrap-netdata + (lambda* (#:key inputs outputs #:allow-other-keys) + (wrap-program + (string-append (assoc-ref outputs "out") "/sbin/netdata") + `("DO_NOT_TRACK" = (,"1")) + `("PYTHONPATH" ":" prefix (,(getenv "PYTHONPATH"))) + `("PATH" ":" prefix ,(map + (lambda (input) + (string-append + (assoc-ref inputs input) + "/bin")) + '("coreutils" "grep" "findutils" "sed" + "dmidecode" "hddtemp" "iproute2" + "iw" "lm-sensors" "netcat" "curl" + "fping" "procps" "which" "gawk" + "node")))) + #t))))) + (native-inputs + `(("git" ,git-minimal) + ("pkg-config" ,pkg-config) + ("protobuf-c" ,protobuf-c) + ("autoconf" ,autoconf) + ("automake" ,automake))) + (inputs + ;; TODO: Add optional libnetfilter-acct + `(("util-linux:lib" ,util-linux "lib") ;; for libuuid + ("libuv" ,libuv) + ("zlib" ,zlib) + ("openssl" ,openssl) + ("lz4" ,lz4) + ("libcap" ,libcap) + ("libmnl" ,libmnl) + ("snappy" ,snappy) + ("cups" ,cups-minimal) + ("python" ,python) + ("python-pyyaml" ,python-pyyaml) + ("python-urllib3" ,python-urllib3) + ("python-six" ,python-six) + ("python-psycopg2" ,python-psycopg2) + ("python-pymysql" ,python-pymysql) + ("python-requests" ,python-requests) + ;; TODO: Add apcupsd + ("coreutils" ,coreutils) + ("grep" ,grep) + ("findutils" ,findutils) + ("sed" ,sed) + ("dmidecode" ,dmidecode) + ("hddtemp" ,hddtemp) + ("iproute2" ,iproute) + ("iw" ,iw) + ("lm-sensors" ,lm-sensors) + ("netcat" ,netcat-openbsd) + ("curl" ,curl) + ("fping" ,fping) + ("procps" ,procps) + ("which" ,which) + ("gawk" ,gawk) + ("node" ,node))) + (home-page "https://www.netdata.cloud/") + (synopsis "Zero-configuration real-time performance monitoring") + (description "Netdata's distributed, real-time monitoring Agent collects +thousands of metrics from systems, hardware, containers, and applications with +zero configuration.") + (license license:gpl3))) diff --git a/gnu/packages/patches/netdata-0001-use-system-python.patch b/gnu/packages/patches/netdata-0001-use-system-python.patch new file mode 100644 index 0000000000..5a14159d52 --- /dev/null +++ b/gnu/packages/patches/netdata-0001-use-system-python.patch @@ -0,0 +1,131 @@ +Author: Lennart Weller <lhw <at> ring0.de> +Description: Ignore embedded python modules. + +diff -Naurp netdata.orig/collectors/python.d.plugin/Makefile.am netdata/collectors/python.d.plugin/Makefile.am +--- netdata.orig/collectors/python.d.plugin/Makefile.am ++++ netdata/collectors/python.d.plugin/Makefile.am +@@ -145,109 +145,3 @@ dist_third_party_DATA = \ + python_modules/third_party/monotonic.py \ + python_modules/third_party/filelock.py \ + $(NULL) +- +-pythonyaml2dir=$(pythonmodulesdir)/pyyaml2 +-dist_pythonyaml2_DATA = \ +- python_modules/pyyaml2/__init__.py \ +- python_modules/pyyaml2/composer.py \ +- python_modules/pyyaml2/constructor.py \ +- python_modules/pyyaml2/cyaml.py \ +- python_modules/pyyaml2/dumper.py \ +- python_modules/pyyaml2/emitter.py \ +- python_modules/pyyaml2/error.py \ +- python_modules/pyyaml2/events.py \ +- python_modules/pyyaml2/loader.py \ +- python_modules/pyyaml2/nodes.py \ +- python_modules/pyyaml2/parser.py \ +- python_modules/pyyaml2/reader.py \ +- python_modules/pyyaml2/representer.py \ +- python_modules/pyyaml2/resolver.py \ +- python_modules/pyyaml2/scanner.py \ +- python_modules/pyyaml2/serializer.py \ +- python_modules/pyyaml2/tokens.py \ +- $(NULL) +- +-pythonyaml3dir=$(pythonmodulesdir)/pyyaml3 +-dist_pythonyaml3_DATA = \ +- python_modules/pyyaml3/__init__.py \ +- python_modules/pyyaml3/composer.py \ +- python_modules/pyyaml3/constructor.py \ +- python_modules/pyyaml3/cyaml.py \ +- python_modules/pyyaml3/dumper.py \ +- python_modules/pyyaml3/emitter.py \ +- python_modules/pyyaml3/error.py \ +- python_modules/pyyaml3/events.py \ +- python_modules/pyyaml3/loader.py \ +- python_modules/pyyaml3/nodes.py \ +- python_modules/pyyaml3/parser.py \ +- python_modules/pyyaml3/reader.py \ +- python_modules/pyyaml3/representer.py \ +- python_modules/pyyaml3/resolver.py \ +- python_modules/pyyaml3/scanner.py \ +- python_modules/pyyaml3/serializer.py \ +- python_modules/pyyaml3/tokens.py \ +- $(NULL) +- +-python_urllib3dir=$(pythonmodulesdir)/urllib3 +-dist_python_urllib3_DATA = \ +- python_modules/urllib3/__init__.py \ +- python_modules/urllib3/_collections.py \ +- python_modules/urllib3/connection.py \ +- python_modules/urllib3/connectionpool.py \ +- python_modules/urllib3/exceptions.py \ +- python_modules/urllib3/fields.py \ +- python_modules/urllib3/filepost.py \ +- python_modules/urllib3/response.py \ +- python_modules/urllib3/poolmanager.py \ +- python_modules/urllib3/request.py \ +- $(NULL) +- +-python_urllib3_utildir=$(python_urllib3dir)/util +-dist_python_urllib3_util_DATA = \ +- python_modules/urllib3/util/__init__.py \ +- python_modules/urllib3/util/connection.py \ +- python_modules/urllib3/util/request.py \ +- python_modules/urllib3/util/response.py \ +- python_modules/urllib3/util/retry.py \ +- python_modules/urllib3/util/selectors.py \ +- python_modules/urllib3/util/ssl_.py \ +- python_modules/urllib3/util/timeout.py \ +- python_modules/urllib3/util/url.py \ +- python_modules/urllib3/util/wait.py \ +- $(NULL) +- +-python_urllib3_packagesdir=$(python_urllib3dir)/packages +-dist_python_urllib3_packages_DATA = \ +- python_modules/urllib3/packages/__init__.py \ +- python_modules/urllib3/packages/ordered_dict.py \ +- python_modules/urllib3/packages/six.py \ +- $(NULL) +- +-python_urllib3_backportsdir=$(python_urllib3_packagesdir)/backports +-dist_python_urllib3_backports_DATA = \ +- python_modules/urllib3/packages/backports/__init__.py \ +- python_modules/urllib3/packages/backports/makefile.py \ +- $(NULL) +- +-python_urllib3_ssl_match_hostnamedir=$(python_urllib3_packagesdir)/ssl_match_hostname +-dist_python_urllib3_ssl_match_hostname_DATA = \ +- python_modules/urllib3/packages/ssl_match_hostname/__init__.py \ +- python_modules/urllib3/packages/ssl_match_hostname/_implementation.py \ +- $(NULL) +- +-python_urllib3_contribdir=$(python_urllib3dir)/contrib +-dist_python_urllib3_contrib_DATA = \ +- python_modules/urllib3/contrib/__init__.py \ +- python_modules/urllib3/contrib/appengine.py \ +- python_modules/urllib3/contrib/ntlmpool.py \ +- python_modules/urllib3/contrib/pyopenssl.py \ +- python_modules/urllib3/contrib/securetransport.py \ +- python_modules/urllib3/contrib/socks.py \ +- $(NULL) +- +-python_urllib3_securetransportdir=$(python_urllib3_contribdir)/_securetransport +-dist_python_urllib3_securetransport_DATA = \ +- python_modules/urllib3/contrib/_securetransport/__init__.py \ +- python_modules/urllib3/contrib/_securetransport/bindings.py \ +- python_modules/urllib3/contrib/_securetransport/low_level.py \ +- $(NULL) +diff -Naurp netdata.orig/collectors/python.d.plugin/python_modules/bases/loaders.py netdata/collectors/python.d.plugin/python_modules/bases/loaders.py +--- netdata.orig/collectors/python.d.plugin/python_modules/bases/loaders.py ++++ netdata/collectors/python.d.plugin/python_modules/bases/loaders.py +@@ -9,10 +9,7 @@ from sys import version_info + PY_VERSION = version_info[:2] + + try: +- if PY_VERSION > (3, 1): +- from pyyaml3 import SafeLoader as YamlSafeLoader +- else: +- from pyyaml2 import SafeLoader as YamlSafeLoader ++ from yaml import SafeLoader as YamlSafeLoader + except ImportError: + from yaml import SafeLoader as YamlSafeLoader + diff --git a/gnu/packages/patches/netdata-0002-use-system-exim4.patch b/gnu/packages/patches/netdata-0002-use-system-exim4.patch new file mode 100644 index 0000000000..0e23618399 --- /dev/null +++ b/gnu/packages/patches/netdata-0002-use-system-exim4.patch @@ -0,0 +1,12 @@ +Author: Sven Hartge <sven <at> svenhartge.de> +Description: Debian has exim in /usr/sbin which is not in the default path. + +diff -Naurp netdata.orig/collectors/python.d.plugin/exim/exim.conf netdata/collectors/python.d.plugin/exim/exim.conf +--- netdata.orig/collectors/python.d.plugin/exim/exim.conf ++++ netdata/collectors/python.d.plugin/exim/exim.conf +@@ -88,4 +88,4 @@ update_every: 10 + # AUTO-DETECTION JOBS + + local: +- command: 'exim -bpc' ++ command: '/usr/sbin/exim -bpc' diff --git a/gnu/packages/patches/netdata-0003-use-python3.patch b/gnu/packages/patches/netdata-0003-use-python3.patch new file mode 100644 index 0000000000..e55089271a --- /dev/null +++ b/gnu/packages/patches/netdata-0003-use-python3.patch @@ -0,0 +1,29 @@ +Author: Sander Klein <debian-bugs <at> roedie.nl> +Description: Debian uses by default python 2 instead of python3. + +diff -Naurp netdata.orig/collectors/python.d.plugin/python.d.plugin.in netdata/collectors/python.d.plugin/python.d.plugin.in +--- netdata.orig/collectors/python.d.plugin/python.d.plugin.in ++++ netdata/collectors/python.d.plugin/python.d.plugin.in +@@ -1,21 +1,4 @@ +-#!/usr/bin/env bash +-'''':; +-pybinary=$(which python || which python3 || which python2) +-filtered=() +-for arg in "$@" +-do +- case $arg in +- -p*) pybinary=${arg:2} +- shift 1 ;; +- *) filtered+=("$arg") ;; +- esac +-done +-if [ "$pybinary" = "" ] +-then +- echo "ERROR python IS NOT AVAILABLE IN THIS SYSTEM" +- exit 1 +-fi +-exec "$pybinary" "$0" "${filtered[@]}" # ''' ++#!/usr/bin/python3 + + # -*- coding: utf-8 -*- + # Description: diff --git a/gnu/packages/patches/netdata-0004-use-sh.patch b/gnu/packages/patches/netdata-0004-use-sh.patch new file mode 100644 index 0000000000..6c8e93bfba --- /dev/null +++ b/gnu/packages/patches/netdata-0004-use-sh.patch @@ -0,0 +1,12 @@ +Author: Daniel Baumann <daniel.baumann <at> progress-linux.org> +Description: Fix shebang hack to not depend on bash. + +diff -Naurp netdata.orig/collectors/node.d.plugin/node.d.plugin.in netdata/collectors/node.d.plugin/node.d.plugin.in +--- netdata.orig/collectors/node.d.plugin/node.d.plugin.in ++++ netdata/collectors/node.d.plugin/node.d.plugin.in +@@ -1,4 +1,4 @@ +-#!/usr/bin/env bash ++#!/bin/sh + ':' //; exec "$(command -v nodejs || command -v node || echo "ERROR node IS NOT AVAILABLE IN THIS SYSTEM")" "$0" "$@" + + // shebang hack from: diff --git a/gnu/packages/patches/netdata-0005-use-bash.patch b/gnu/packages/patches/netdata-0005-use-bash.patch new file mode 100644 index 0000000000..53b7fc5b31 --- /dev/null +++ b/gnu/packages/patches/netdata-0005-use-bash.patch @@ -0,0 +1,13 @@ +Author: Daniel Baumann <daniel.baumann <at> progress-linux.org> +Description: Using bash instead of sh for edit-config. + It reads /etc/profile which often contains bash specific configuration. + +diff -Naurp netdata.orig/system/edit-config.in netdata/system/edit-config.in +--- netdata.orig/system/edit-config.in ++++ netdata/system/edit-config.in +@@ -1,4 +1,4 @@ +-#!/usr/bin/env sh ++#!/bin/bash + + [ -f /etc/profile ] && . /etc/profile + diff --git a/gnu/packages/patches/netdata-no-files-in-etc-and-var.patch b/gnu/packages/patches/netdata-no-files-in-etc-and-var.patch new file mode 100644 index 0000000000..594805fdf1 --- /dev/null +++ b/gnu/packages/patches/netdata-no-files-in-etc-and-var.patch @@ -0,0 +1,129 @@ +From 4ecc1475be94a384c122594b5f7d455beb64a2f0 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?J=C3=B6rg=20Thalheim?= <joerg <at> thalheim.io> +Date: Sat, 22 Feb 2020 06:42:14 +0000 +Subject: [PATCH] no files in etc and var +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +Signed-off-by: Jörg Thalheim <joerg <at> thalheim.io> +--- + collectors/Makefile.am | 2 +- + collectors/charts.d.plugin/Makefile.am | 2 +- + collectors/node.d.plugin/Makefile.am | 2 +- + collectors/python.d.plugin/Makefile.am | 2 +- + collectors/statsd.plugin/Makefile.am | 2 +- + health/Makefile.am | 2 +- + system/Makefile.am | 3 +-- + web/Makefile.am | 2 +- + 8 files changed, 8 insertions(+), 9 deletions(-) + +diff --git a/collectors/Makefile.am b/collectors/Makefile.am +index 9bb52958..c9799165 100644 +--- a/collectors/Makefile.am ++++ b/collectors/Makefile.am +@@ -32,7 +32,7 @@ usercustompluginsconfigdir=$(configdir)/custom-plugins.d + usergoconfigdir=$(configdir)/go.d + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(usercustompluginsconfigdir) + $(INSTALL) -d $(DESTDIR)$(usergoconfigdir) + +diff --git a/collectors/charts.d.plugin/Makefile.am b/collectors/charts.d.plugin/Makefile.am +index 03c7f0a9..01985db0 100644 +--- a/collectors/charts.d.plugin/Makefile.am ++++ b/collectors/charts.d.plugin/Makefile.am +@@ -34,7 +34,7 @@ dist_userchartsconfig_DATA = \ + $(NULL) + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(userchartsconfigdir) + + chartsconfigdir=$(libconfigdir)/charts.d +diff --git a/collectors/node.d.plugin/Makefile.am b/collectors/node.d.plugin/Makefile.am +index c3142d43..95e32445 100644 +--- a/collectors/node.d.plugin/Makefile.am ++++ b/collectors/node.d.plugin/Makefile.am +@@ -26,7 +26,7 @@ dist_usernodeconfig_DATA = \ + $(NULL) + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(usernodeconfigdir) + + nodeconfigdir=$(libconfigdir)/node.d +diff --git a/collectors/python.d.plugin/Makefile.am b/collectors/python.d.plugin/Makefile.am +index e678f86a..29a319da 100644 +--- a/collectors/python.d.plugin/Makefile.am ++++ b/collectors/python.d.plugin/Makefile.am +@@ -32,7 +32,7 @@ dist_userpythonconfig_DATA = \ + $(NULL) + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(userpythonconfigdir) + + pythonconfigdir=$(libconfigdir)/python.d +diff --git a/collectors/statsd.plugin/Makefile.am b/collectors/statsd.plugin/Makefile.am +index b01302d1..f5b77da4 100644 +--- a/collectors/statsd.plugin/Makefile.am ++++ b/collectors/statsd.plugin/Makefile.am +@@ -17,5 +17,5 @@ dist_userstatsdconfig_DATA = \ + $(NULL) + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(userstatsdconfigdir) +diff --git a/health/Makefile.am b/health/Makefile.am +index 853ed0d7..210330a6 100644 +--- a/health/Makefile.am ++++ b/health/Makefile.am +@@ -19,7 +19,7 @@ dist_userhealthconfig_DATA = \ + $(NULL) + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(userhealthconfigdir) + + healthconfigdir=$(libconfigdir)/health.d +diff --git a/system/Makefile.am b/system/Makefile.am +index ad68c655..74f032f9 100644 +--- a/system/Makefile.am ++++ b/system/Makefile.am +@@ -17,11 +17,10 @@ include $(top_srcdir)/build/subst.inc + SUFFIXES = .in + + dist_config_SCRIPTS = \ +- edit-config \ + $(NULL) + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(configdir) + + nodist_noinst_DATA = \ +diff --git a/web/Makefile.am b/web/Makefile.am +index ccaccd76..16a2977e 100644 +--- a/web/Makefile.am ++++ b/web/Makefile.am +@@ -12,7 +12,7 @@ SUBDIRS = \ + usersslconfigdir=$(configdir)/ssl + + # Explicitly install directories to avoid permission issues due to umask +-install-exec-local: ++no-install-exec-local: + $(INSTALL) -d $(DESTDIR)$(usersslconfigdir) + + dist_noinst_DATA = \ +-- +2.25.0 + diff --git a/gnu/packages/patches/netdata-web-remove-antifeatures-spyware.patch b/gnu/packages/patches/netdata-web-remove-antifeatures-spyware.patch new file mode 100644 index 0000000000..0b3be9a5d2 --- /dev/null +++ b/gnu/packages/patches/netdata-web-remove-antifeatures-spyware.patch @@ -0,0 +1,4466 @@ +diff --git a/registry/registry_init.c b/registry/registry_init.c +index ffdb83f3..2d5460fd 100644 +--- a/registry/registry_init.c ++++ b/registry/registry_init.c +@@ -36,7 +36,7 @@ int registry_init(void) { + registry.save_registry_every_entries = (unsigned long long)config_get_number(CONFIG_SECTION_REGISTRY, "registry save db every new entries", 1000000); + registry.persons_expiration = config_get_number(CONFIG_SECTION_REGISTRY, "registry expire idle persons days", 365) * 86400; + registry.registry_domain = config_get(CONFIG_SECTION_REGISTRY, "registry domain", ""); +- registry.registry_to_announce = config_get(CONFIG_SECTION_REGISTRY, "registry to announce", "https://registry.my-netdata.io"); ++ registry.registry_to_announce = config_get(CONFIG_SECTION_REGISTRY, "registry to announce", ""); + registry.hostname = config_get(CONFIG_SECTION_REGISTRY, "registry hostname", netdata_configured_hostname); + registry.verify_cookies_redirects = config_get_boolean(CONFIG_SECTION_REGISTRY, "verify browser cookies support", 1); + +diff --git a/web/gui/Makefile.am b/web/gui/Makefile.am +index c69380f9..8a8f01e5 100644 +--- a/web/gui/Makefile.am ++++ b/web/gui/Makefile.am +@@ -46,10 +46,6 @@ dist_noinst_DATA = \ + $(NULL) + + dist_web_DATA = \ +- demo.html \ +- demo2.html \ +- demosites.html \ +- demosites2.html \ + dashboard.html \ + dashboard.js \ + dashboard_info.js \ +@@ -62,7 +58,6 @@ dist_web_DATA = \ + main.css \ + main.js \ + console.html \ +- infographic.html \ + robots.txt \ + refresh-badges.js \ + sitemap.xml \ +diff --git a/web/gui/console.html b/web/gui/console.html +index b85b4ffb..2debd1c5 100644 +--- a/web/gui/console.html ++++ b/web/gui/console.html +@@ -12,18 +12,6 @@ + <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" /> + <link rel="icon" href="" /> + <link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons" /> +- <!-- Google Tag Manager --> +- <script>(function (w, d, s, l, i) { +- w[l] = w[l] || []; w[l].push({ +- 'gtm.start': +- new Date().getTime(), event: 'gtm.js' +- }); var f = d.getElementsByTagName(s)[0], +- j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src = +- 'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f); +- })(window, document, 'script', 'dataLayer', 'GTM-N6CBMJD'); +- window.dataLayer = window.dataLayer || []; +- </script> +- <!-- End Google Tag Manager --> + <script> + function loadJSFile(filename) { + const s = document.createElement("script") +@@ -39,28 +27,13 @@ + l.setAttribute("href", filename) + document.getElementsByTagName("head")[0].appendChild(l) + } +- +- var cloudBaseURL = localStorage.getItem("cloud.baseURL") || "https://netdata.cloud" +- +- loadCSSFile(`${cloudBaseURL}/static/console/main.css?v=4`) + </script> + </head> + + <body class="mdc-theme--background mdc-typography"> +- <!-- Google Tag Manager (noscript) --> +- <noscript> +- <iframe src="https://www.googletagmanager.com/ns.html?id=GTM-N6CBMJD" height="0" width="0" +- style="display:none;visibility:hidden"></iframe> +- </noscript> +- <!-- End Google Tag Manager (noscript) --> + <main id="app" class="console-app" data-host="agent"></main> + <script> + const main = document.getElementById("app") +- main.setAttribute("data-static-base-url", cloudBaseURL) +- main.setAttribute("data-api-base-url", cloudBaseURL) +- main.setAttribute("data-api-base-url-v2", cloudBaseURL) +- +- loadJSFile(`${cloudBaseURL}/static/console/main.js?v=4`) + </script> + <script> + var netdataTheme = "white" +diff --git a/web/gui/dashboard.js b/web/gui/dashboard.js +index 53e9090b..0afa0d0f 100644 +--- a/web/gui/dashboard.js ++++ b/web/gui/dashboard.js +@@ -9926,25 +9926,14 @@ NETDATA.alarms = { + + NETDATA.registry = { + server: null, // the netdata registry server +- isCloudEnabled: false,// is netdata.cloud functionality enabled? +- cloudBaseURL: null, // the netdata cloud base url + person_guid: null, // the unique ID of this browser / user + machine_guid: null, // the unique ID the netdata server that served dashboard.js + hostname: 'unknown', // the hostname of the netdata server that served dashboard.js + machines: null, // the user's other URLs + machines_array: null, // the user's other URLs in an array + person_urls: null, +- anonymous_statistics_checked: false, + MASKED_DATA: "***", + +- isUsingGlobalRegistry: function() { +- return NETDATA.registry.server == "https://registry.my-netdata.io"; +- }, +- +- isRegistryEnabled: function() { +- return !(NETDATA.registry.isUsingGlobalRegistry() || isSignedIn()) +- }, +- + parsePersonUrls: function (person_urls) { + NETDATA.registry.person_urls = person_urls; + +@@ -9998,26 +9987,8 @@ NETDATA.registry = { + NETDATA.registry.hello(NETDATA.serverDefault, function (data) { + if (data) { + NETDATA.registry.server = data.registry; +- if (data.cloud_base_url !== "") { +- NETDATA.registry.isCloudEnabled = true; +- NETDATA.registry.cloudBaseURL = data.cloud_base_url; +- } else { +- NETDATA.registry.isCloudEnabled = false; +- NETDATA.registry.cloudBaseURL = ""; +- } + NETDATA.registry.machine_guid = data.machine_guid; + NETDATA.registry.hostname = data.hostname; +- if (!NETDATA.registry.anonymous_statistics_checked) { +- NETDATA.registry.anonymous_statistics_checked=true; +- if (data.anonymous_statistics) { +- (function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start': +- new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0], +- j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=false;j.src= +- 'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f); +- })(window,document,'script','dataLayer','GTM-N6CBMJD'); +- dataLayer.push({"anonymous_statistics" : "true", "machine_guid" : data.machine_guid}); +- } +- } + NETDATA.registry.access(2, function (person_urls) { + NETDATA.registry.parsePersonUrls(person_urls); + }); +@@ -10066,12 +10037,8 @@ NETDATA.registry = { + let name = NETDATA.registry.MASKED_DATA; + let url = NETDATA.registry.MASKED_DATA; + +- if (!NETDATA.registry.isUsingGlobalRegistry()) { +- // If the user is using a private registry keep sending identifiable +- // data. +- name = NETDATA.registry.hostname; +- url = NETDATA.serverDefault; +- } ++ name = NETDATA.registry.hostname; ++ url = NETDATA.serverDefault; + + console.log("ACCESS", name, url); + +diff --git a/web/gui/dashboard_info.js b/web/gui/dashboard_info.js +index 1f289ba0..889b6827 100644 +--- a/web/gui/dashboard_info.js ++++ b/web/gui/dashboard_info.js +@@ -196,11 +196,6 @@ netdataDashboard.menu = { + info: 'Performance metrics for the operation of netdata itself and its plugins.' + }, + +- 'aclk_test': { +- title: 'ACLK Test Generator', +- info: 'For internal use to perform integration testing.' +- }, +- + 'example': { + title: 'Example Charts', + info: 'Example charts, demonstrating the external plugin architecture.' +@@ -3353,21 +3348,6 @@ netdataDashboard.context = { + info: 'Difference between the number of process created and the number of threads created per period(<code>process</code> dimension), it also shows the number of possible zombie process running on system.' + }, + +- // ------------------------------------------------------------------------ +- // ACLK Internal Stats +- 'netdata.aclk_status': { +- valueRange: "[0, 1]", +- info: 'This chart shows if ACLK was online during entirety of the sample duration.' +- }, +- +- 'netdata.aclk_query_per_second': { +- info: 'This chart shows how many queries were added for ACLK_query thread to process and how many it was actually able to process.' +- }, +- +- 'netdata.aclk_latency_mqtt': { +- info: 'Measures latency between MQTT publish of the message and it\'s PUB_ACK being received' +- }, +- + // ------------------------------------------------------------------------ + // VerneMQ + +diff --git a/web/gui/demo.html b/web/gui/demo.html +deleted file mode 100644 +index b096bef3..00000000 +--- a/web/gui/demo.html ++++ /dev/null +@@ -1,51 +0,0 @@ +-<!DOCTYPE html> +-<!-- SPDX-License-Identifier: GPL-3.0-or-later --> +-<html lang="en"> +-<head> +- <title>NetData Dashboard</title> +- <meta name="application-name" content="netdata"> +- +- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +- <meta charset="utf-8"> +- <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> +- <meta name="viewport" content="width=device-width, initial-scale=1"> +- <meta name="apple-mobile-web-app-capable" content="yes"> +- <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"> +- <meta name="author" content="costa <at> tsaousis.gr"> +- +- <meta property="og:locale" content="en_US" /> +- <meta property="og:image" content="https://cloud.githubusercontent.com/assets/2662304/22945737/e98cd0c6-f2fd-11e6-96f1-5501934b0955.png"/> +- <meta property="og:url" content="http://my-netdata.io/"/> +- <meta property="og:type" content="website"/> +- <meta property="og:site_name" content="netdata"/> +- <meta property="og:title" content="netdata - real-time performance monitoring, done right!"/> +- <meta property="og:description" content="Stunning real-time dashboards, blazingly fast and extremely interactive. Zero configuration, zero dependencies, zero maintenance." /> +-</head> +-<script type="text/javascript" src="dashboard.js?v20190902-0"></script> +-<body> +- +-<div style="width: 100%; text-align: center;"> +- <div data-netdata="netdata.server_cpu" +- data-dimensions="user" +- data-chart-library="gauge" +- data-width="150px" +- data-after="-60" +- data-points="60" +- data-title="Yes! Realtime!" +- data-units="I am alive!" +- data-colors="#FF5555" +- ></div> +- <br/> +- <div data-netdata="netdata.server_cpu" +- data-dimensions="user" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-width="200px" +- data-height="30px" +- data-after="-60" +- data-points="60" +- data-colors="#FF5555" +- ></div> +-</div> +-</body> +-</html> +diff --git a/web/gui/demo2.html b/web/gui/demo2.html +deleted file mode 100644 +index 650acfe0..00000000 +--- a/web/gui/demo2.html ++++ /dev/null +@@ -1,143 +0,0 @@ +-<!DOCTYPE html> +-<!-- SPDX-License-Identifier: GPL-3.0-or-later --> +-<html lang="en"> +-<head> +- <title>NetData Dashboard</title> +- <meta name="application-name" content="netdata"> +- +- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +- <meta charset="utf-8"> +- <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> +- <meta name="viewport" content="width=device-width, initial-scale=1"> +- <meta name="apple-mobile-web-app-capable" content="yes"> +- <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"> +- <meta name="author" content="costa <at> tsaousis.gr"> +- +- <meta property="og:locale" content="en_US" /> +- <meta property="og:image" content="https://cloud.githubusercontent.com/assets/2662304/22945737/e98cd0c6-f2fd-11e6-96f1-5501934b0955.png"/> +- <meta property="og:url" content="https://my-netdata.io/"/> +- <meta property="og:type" content="website"/> +- <meta property="og:site_name" content="netdata"/> +- <meta property="og:title" content="netdata - real-time performance monitoring, done right!"/> +- <meta property="og:description" content="Stunning real-time dashboards, blazingly fast and extremely interactive. Zero configuration, zero dependencies, zero maintenance." /> +-</head> +-<script>var netdataTheme = 'slate';</script> +-<script type="text/javascript" src="https://my-netdata.io/dashboard.js?v20190902-0"></script> +-<body> +- +-<div class="container" style="width: 90%; padding-top: 10px; text-align: center; color: #AAA"> +- <div style="font-size: 7vw;">why netdata?</div> +- <br/> +- <div style="font-size: 2vw; color: white;">These charts visualize the same data...</div> +- +- +- <!-- Nav tabs --> +- <ul class="nav nav-tabs" role="tablist"> +- <li role="presentation" class="active"><a href="#gauge" aria-controls="gauge" role="tab" data-toggle="tab">Gauge.js</a></li> +- <li role="presentation"><a href="#easypiechart" aria-controls="easypiechart" role="tab" data-toggle="tab">Easy Pie Chart</a></li> +- </ul> +- +- <!-- Tab panes --> +- <div class="tab-content"> +- <div role="tabpanel" class="tab-pane active" id="gauge"> +- +- <div style="display: inline-block; width: 35.8%"> +- <div style="font-size: 1.2vw; color: #666; padding-top: 10px;"><i class="fa fa-comment"></i> I can trace an issue like this</div> +- <br/> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-chart-library="gauge" +- data-gauge-max-value="32767" +- data-width="100%" +- data-after="-600" +- data-points="600" +- data-title="1/second (netdata default)" +- data-units="important metric" +- data-colors="#5A5" +- ></div> +- </div> +- <div style="display: inline-block; width: 50%"> +- <div style="font-size: 1.2vw; color: #666;"><i class="fa fa-comment"></i> Can you trace an issue like these?<br/> <br/></div> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-chart-library="gauge" +- data-gauge-max-value="32767" +- data-width="45%" +- data-after="-600" +- data-points="60" +- data-title="Updates Every 10 Sec" +- data-units="important metric" +- data-colors="#C55" +- ></div> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-chart-library="gauge" +- data-gauge-max-value="32767" +- data-width="45%" +- data-after="-600" +- data-points="2" +- data-title="Updates Every 5 Mins" +- data-units="important metric" +- data-colors="#C55" +- ></div> +- </div> +- </div> +- <div role="tabpanel" class="tab-pane" id="easypiechart"> +- +- <div style="display: inline-block; width: 25%"> +- <div style="font-size: 1.2vw; color: #666; padding-top: 10px;"><i class="fa fa-comment"></i> I can trace an issue like this</div> +- <br/> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-chart-library="easypiechart" +- data-easypiechart-max-value="32767" +- data-width="100%" +- data-after="-600" +- data-points="600" +- data-title="1/second (netdata default)" +- data-units="important metric" +- data-colors="#5A5" +- ></div> +- </div> +- <div style="display: inline-block; width: 40%"> +- <div style="font-size: 1.2vw; color: #666;"><i class="fa fa-comment"></i> Can you trace an issue like these?<br/> <br/></div> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-chart-library="easypiechart" +- data-easypiechart-max-value="32767" +- data-width="45%" +- data-after="-600" +- data-points="60" +- data-title="Updates Every 10 Sec" +- data-units="important metric" +- data-colors="#C55" +- ></div> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-chart-library="easypiechart" +- data-easypiechart-max-value="32767" +- data-width="45%" +- data-after="-600" +- data-points="2" +- data-title="Updates Every 5 Mins" +- data-units="important metric" +- data-colors="#C55" +- ></div> +- </div> +- </div> +- </div> +- <div style="font-size: 1.5vw;">Hover on the chart below, to see the selected value on the charts above!</div> +- <div data-netdata="example.random2" +- data-dimensions="random" +- data-dygraph-theme="sparkline" +- data-width="100%" +- data-height="20vh" +- data-after="-600" +- data-points="600" +- data-title="1/second (netdata default)" +- data-units="something" +- data-colors="#888" +- ></div> +-</div> +-</body> +-</html> +diff --git a/web/gui/demosites.html b/web/gui/demosites.html +deleted file mode 100644 +index e8a310a1..00000000 +--- a/web/gui/demosites.html ++++ /dev/null +@@ -1,1469 +0,0 @@ +-<!doctype html> +-<!-- SPDX-License-Identifier: GPL-3.0-or-later --> +-<html lang=en-us xmlns="http://www.w3.org/1999/html"> +-<head> +- <meta http-equiv="Refresh" content="0; url=https://www.netdata.cloud"> +- <meta charset=utf-8> +- <title>NetData: Get control of your Linux Servers. Simple. Effective. Awesome.</title> +- <meta name=author content="Costa Tsaousis"> +- <meta name=description content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms."> +- +- <meta name=viewport content="width=device-width,initial-scale=1"> +- <link rel=apple-touch-icon href=apple-touch-icon.png> +- <link rel="icon" href="" /> +- +- <meta property="og:url" content="https://my-netdata.io" /> +- <meta property="og:type" content="website" /> +- <meta property="og:title" content="Get control of your Linux Servers. Simple. Effective. Awesome." /> +- <meta property="og:description" content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms." /> +- <meta property="og:image" content="https://cloud.githubusercontent.com/assets/2662304/22945737/e98cd0c6-f2fd-11e6-96f1-5501934b0955.png" /> +- <meta property="og:image:type" content="image/png" /> +- <meta property="fb:app_id" content="1200089276712916" /> +- +- <meta name="twitter:card" content="summary" /> +- <meta name="twitter:site" content="@linuxnetdata" /> +- <meta name="twitter:title" content="Get control of your Linux Servers. Simple. Effective. Awesome." /> +- <meta name="twitter:description" content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms." /> +- <meta name="twitter:image" content="https://cloud.githubusercontent.com/assets/2662304/14092712/93b039ea-f551-11e5-822c-beadbf2b2a2e.gif" /> +- +- <meta name="google-site-verification" content="3Xmk2kyCvai8p9HEnYHoQ9RBW20-b1NvPAgu07Fkkds" /> +- <meta name="msvalidate.01" content="896DCA31C9A664CE359FCF1A645DD476" /> +- +- <style>/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */ +-html { +- line-height: 1.15; +- -ms-text-size-adjust: 100%; +- -webkit-text-size-adjust: 100%; +- color: #fff; +- font: 17px/1.4 'Open Sans', sans-serif; +- text-align: center +-} +- +-body { +- margin: 0; +- background-color: #2f3135; +- background-image: url() +-} +- +-a { +- background-color: transparent; +- -webkit-text-decoration-skip: objects; +- color: #069; +- text-decoration: none +-} +- +-a:active, a:hover { +- outline-width: 0 +-} +- +-strong { +- font-weight: bolder +-} +- +-h1 { +- font-size: 2.9em; +- line-height: 1.2em; +- margin: 0 .5em .75em +-} +- +-img { +- border-style: none; +- vertical-align: middle +-} +- +-[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner { +- border-style: none; +- padding: 0 +-} +- +-[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring { +- outline: 1px dotted ButtonText +-} +- +-a:active, a:focus, a:hover { +- text-decoration: underline; +-} +- +-::-moz-selection { +- background-color: #b3d4fc; +- text-shadow: none; +-} +- +-::selection { +- background-color: #b3d4fc; +- text-shadow: none; +-} +- +-h2 { +- font-size: 2em; +- margin: 1.5em 0; +-} +- +-h3 { +- color: #555; +- font-size: 1.5em; +- margin: 0 0 .5em; +-} +- +-p { +- margin: 0 0 2em; +-} +- +-.quote { +- font-size: 1.15em; +- margin: 0 0 .5em; +- text-align: center; +-} +- +-.title { +- /* opacity: 0; */ +- /* transition: opacity 500ms; */ +-} +- +-.titlefadein { +- opacity: 1; +- transition: opacity 500ms; +-} +- +-.grid { +- margin: 0 -15px; +- letter-spacing: -.31em; +- word-spacing: -.43em; +- text-rendering: optimizespeed +-} +- +-.grid-title { +- text-align: left; +-} +- +-.grid-cell { +- display: inline-block; +- letter-spacing: normal; +- text-align: left; +- text-rendering: auto; +- vertical-align: top; +- width: 50%; +- word-spacing: normal +-} +- +-.grid-cell > * { +- padding: 0 15px +-} +- +-.inline-block-list { +- list-style-type: none; +- margin: 0; +- padding: 0 +-} +- +-.inline-block-list li { +- display: inline-block; +- margin: 0 0 0 1.5em; +- padding: 0; +- vertical-align: top +-} +- +-.inline-block-list li:first-child { +- margin-left: 0 +-} +- +-.flex-embed { +- background-color: #000; +- box-shadow: 0 0 10px #000; +- height: 0; +- overflow: hidden; +- padding-bottom: 56.25%; +- position: relative +-} +- +-.flex-embed a, .flex-embed img { +- bottom: 0; +- height: 100%; +- left: 0; +- position: absolute; +- top: 0; +- width: 100% +-} +- +-.flex-embed .play-btn { +- background: url(); +- height: 150px; +- left: 50%; +- margin-left: -75px; +- margin-top: -75px; +- position: absolute; +- top: 50%; +- -webkit-transition: 1s; +- transition: 1s; +- width: 150px +-} +- +-.flex-embed:hover .play-btn { +- opacity: .5 +-} +- +-.clearfix:after, .clearfix:before { +- content: ' '; +- display: table +-} +- +-.clearfix:after { +- clear: both +-} +- +-.clearfix { +- *zoom: 1 +-} +- +-.container { +- margin: 0 auto; +- max-width: 760px; +- padding: 0 10px +-} +- +-.aside { +- background-color: #eee; +- border: solid #e3e3e3; +- border-width: 1px 0; +- font-size: 1.125em; +- padding: 1em 0 +-} +- +-.btn, .cta-option { +- display: inline-block; +- position: relative +-} +- +-.cta-option { +- margin: 2.5em .5em 0; +- vertical-align: top +-} +- +-.btn { +- color: #fff; +- font-size: 1.5em; +- padding: .6em 1em; +- text-decoration: none; +- text-shadow: 0 -1px 0 rgba(0, 0, 0, .5); +- vertical-align: middle; +- border-radius: 4px; +- border: 1px solid #333 +-} +- +-.btn:active, .btn:focus, .btn:hover { +- text-decoration: none +-} +- +-.btn-download { +- background-color: #d9750b; +- background-image: -webkit-linear-gradient(#f90 10%, #e76a00 100%); +- background-image: linear-gradient(#f90 10%, #e76a00 100%); +- box-shadow: 0 1px 0 rgba(255, 255, 255, .5) inset, 0 1px 3px rgba(0, 0, 0, .2); +- border: 1px solid #995309 +-} +- +-.btn-download:active, .btn-download:focus, .btn-download:hover { +- background-color: #e0811b; +- background-image: -webkit-linear-gradient(#f0a100 10%, #f70 100%); +- background-image: linear-gradient(#f0a100 10%, #f70 100%) +-} +- +-.btn-download:active { +- background-color: #cf6a00; +- box-shadow: 0 2px 3px 0 rgba(0, 0, 0, .2) inset +-} +- +-.btn-alt { +- background-color: #444; +- border-color: #222; +- box-shadow: none; +- font-size: 1.25em; +- margin-top: .25em +-} +- +-.btn-alt:active, .btn-alt:focus, .btn-alt:hover { +- background-color: #555 +-} +- +-.star { +- color: #e08524 +-} +- +-.Icon { +- display: inline-block; +- height: 16px; +- margin: -3px 1px 0 0; +- vertical-align: middle; +- width: 16px +-} +- +-.Icon--github { +- background-image: url() +-} +- +-.Icon--html5 { +- background-image: url() +-} +- +-.Icon--stackoverflow { +- background-image: url() +-} +- +-.site-header { +- padding-top: 50px +-} +- +-.site-logo { +- color: #fff; +- float: left; +- font-size: 25px; +- font-weight: 700; +- line-height: 32px; +- text-decoration: none; +- text-shadow: 2px 2px 0 #000; +- text-transform: uppercase +-} +- +-.site-nav { +- float: right; +- list-style-type: none; +- margin: 7px 0 0; +- padding: 0 +-} +- +-.site-nav a { +- color: #ffa000; +- display: block; +- text-decoration: none; +- text-transform: uppercase +-} +- +-.site-nav a:active, .site-nav a:focus, .site-nav a:hover { +- color: #fff +-} +- +-.site-promo { +- padding: 4em 0 6em; +- color: white; +-} +- +-.site-promo .description { +- color: #ddd; +- font-size: 1.2em; +- margin: 1em 2em 0 +-} +- +-.last-update { +- color: #999; +- display: block; +- font-size: .75em; +- margin-top: 10px +-} +- +-.site-section { +- background-color: #f9f9f9; +- color: #333; +- overflow: hidden; +- padding: 2em 0 2em +-} +- +-.site-section-gray { +- background-color: #f5f5f5; +- color: #333; +- overflow: hidden; +- padding: 2em 0 2em +-} +- +-.site-section-dark { +- background-color: transparent; +- color: #fff; +- text-align: center; +- padding: 2em 0 3em +-} +- +-.site-section-dark .content { +- max-width: 720px; +- margin: auto; +- padding: 10px +-} +- +-.site-section-dark h2 { +- margin: 1em 0 +-} +-.site-section-dark h3 { +- color: white; +-} +- +-.in-the-wild { +- font-size: 1.25em; +- margin: 0 auto; +- max-width: 720px +-} +- +-.site-footer { +- font-size: .875em; +- padding: 2em +-} +- +-.site-footer a { +- color: #ffa000 +-} +- +-@media only screen and (max-width: 800px) { +- .site-logo, .site-nav { +- float: none +- } +- +- .site-nav li { +- margin: 0 .5em +- } +- +- .site-header { +- padding-top: 40px +- } +- +- .site-promo { +- padding: 3em 0; +- color: white; +- } +- +- .site-section { +- padding: 0 1em 4em +- } +-} +- +-@media only screen and (max-width: 600px) { +- html { +- font-size: 14px +- } +- +- .last-update, .site-footer { +- font-size: 1em +- } +-} +- +-@media only screen and (max-width: 460px) { +- .grid-cell { +- width: 100% +- } +-} +- +-@media only screen and (max-width: 420px) { +- h1 { +- font-size: 2.5em +- } +- +- html { +- font-size: 13px +- } +-} +- +-@media print { +- * { +- background-color: transparent !important; +- box-shadow: none !important; +- color: #000 !important; +- text-shadow: none !important +- } +- +- a, a:visited { +- text-decoration: underline +- } +- +- img { +- page-break-inside: avoid; +- max-width: 100% !important +- } +- +- h1 { +- padding: 1em 0 0 +- } +- +- .site-promo { +- margin: 1em; +- padding: 0; +- color: white; +- } +- +- .site-section { +- padding: 0; +- margin: 2em 1em +- } +- +- .site-section-dark { +- display: none +- } +- +- h2, h3, p { +- orphans: 3; +- widows: 3 +- } +- +- h2, h3 { +- page-break-after: avoid +- } +-} +-</style> +- +-<script> +- // --- OPTIONS FOR THE DASHBOARD -- +- +- // this section has to appear before loading dashboard.js +- +- // Select a theme. +- // uncomment on of the two themes: +- +- // var netdataTheme = 'default'; // this is white +- var netdataTheme = 'slate'; // this is dark +- +- var netdataNoBootstrap = true; +- +- // Set the default netdata server. +- // on charts without a 'data-host', this one will be used. +- // the default is the server that dashboard.js is downloaded from. +- +- // var netdataServer = 'http://my.server:19999/'; +-</script> +- +-<!-- +- --- LOAD dashboard.js --- +- +- to host this HTML file on your web server, +- you have to load dashboard.js from the netdata server. +- +- So, pick one the two below +- If you pick the first, set the server name/IP. +- +- The second assumes you host this file on /usr/share/netdata/web +- and that you have chown it to be owned by netdata:netdata +---> +-<!-- <script type="text/javascript" src="http://my.server:19999/dashboard.js"></script> --> +-<script type="text/javascript" src="dashboard.js?v20190902-0"></script> +- +-<script> +- // --- OPTIONS FOR THE CHARTS -- +- +- // destroy charts not shown (lowers memory on the browsers) +- // set this to 'true' to destroy, 'false' to hide the charts +- NETDATA.options.current.destroy_on_hide = false; +- +- // set this to false, to always show all dimensions +- NETDATA.options.current.eliminate_zero_dimensions = true; +- +- // set this to false, to lower the pressure on the browser +- NETDATA.options.current.concurrent_refreshes = true; +- +- // if you need to support slow mobile phones, set this to false +- NETDATA.options.current.parallel_refresher = true; +- +- // set this to false, to always update the charts, even if focus is lost +- NETDATA.options.current.stop_updates_when_focus_is_lost = true; +- +- // since we have many servers and limited sockets, +- // abort ajax calls when we scroll +- NETDATA.options.current.abort_ajax_on_scroll = true; +- +- // do not to give errors on netdata demo servers for 60 seconds +- NETDATA.options.current.retries_on_data_failures = 60; +-</script> +- +-<style> +- .mygauge-combo { +- display: inline-block; +- } +- +- .mygauge-combo20 { +- display: inline-block; +- min-width: 150px; +- width: 49%; +- padding-top: 40px; +- text-align: center; +- } +- +- .mygauge-combo30 { +- display: inline-block; +- min-width: 150px; +- width: 32%; +- padding-top: 40px; +- text-align: center; +- } +- +- .mygauge { +- position: relative; +- display: block; +- width: 171px; +- /* height: 150px; */ +- } +- +- .mygauge-button { +- display: block; +- } +- +- .mygauge-legend-button { +- font-size: 13px; +- } +- +- .mygause-donation { +- font-size: 9px; +- color: #999; +- } +- +- .mysparkline { +- position: relative; +- display: inline-block; +- width: 100%; +- height: 50px; +- text-align: left; +- } +- +- .mysparkline-overchart-label { +- position: absolute; +- display: block; +- top: -15px; +- left: 10px; +- bottom: 0; +- right: 0; +- font-size: 14px; +- z-index: 1; +- pointer-events: none; +- } +- +- .mysparkline-overchart-label2 { +- position: absolute; +- display: block; +- top: -15px; +- left: 10px; +- bottom: 0; +- right: 0; +- font-size: 8px; +- color: #676b70; +- z-index: 1; +- pointer-events: none; +- } +- +- .mysparkline-overchart-value { +- position: absolute; +- display: block; +- top: 0px; +- left: 10px; +- bottom: 0; +- right: 0; +- font-size: 40px; +- z-index: 2; +- text-shadow: #333 0px 0px 2px; +- pointer-events: none; +- } +- +- .mysparkline-overchart-value-center { +- position: absolute; +- display: block; +- top: 5px; +- left: 0px; +- bottom: 0; +- right: 0; +- font-size: 35px; +- font-weight: bold; +- text-align: center; +- z-index: 2; +- text-shadow: #333 0px 0px 2px; +- pointer-events: none; +- } +- +- .fb-share-button span { +- top: 0px; +- } +- .fb-like span { +- top: 0px; +- } +- .fb-follow span { +- top: 0px; +- } +- +-</style> +-</head> +-<body> +-<div class=container> +- <div class="site-header clearfix" role=banner> +- <div class=site-logo>my-netdata.io</div> +- <ul class="site-nav inline-block-list"> +- <li><a href=https://github.com/netdata/netdata data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label="Source code" target="_blank">Source code</a> +- <li><a href=https://docs.netdata.cloud data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Docs target="_blank">Docs</a> +- </ul> +- </div> +- <div class=site-promo><h1><span class="title">Monitor your systems and applications, the right way!</span></h1> +- <p class=description> +- <strong>Unparalleled</strong> insights, in <strong>real-time</strong>, +- of <strong>everything</strong> happening on your systems and applications, +- with stunning, <strong>interactive</strong> web dashboards +- and powerful <strong>performance</strong> and <strong>health</strong> alarms. +- <div class=cta-option> +- <a class="btn btn-download" href="https://docs.netdata.cloud/packaging/installer/" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Install><strong>Install netdata now</strong></a> +- <a class=last-update href="https://github.com/netdata/netdata/releases" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Releases>See netdata releases</a></div> +- <div class=cta-option> +- <a class="btn btn-alt" href="#demosites" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Demo>netdata live demo</a> +- </div> +- </div> +-</div> +-<div class=site-section> +- <div class=container><h2>Enter the world of Netdata!</h2> +- <div class="grid-title"> +- <h3><span class=star>★</span> 1s granularity</h3> +- </div> +- <div class=grid> +- <div class=grid-cell> +- <p> +- <b>Per second</b> data collection and visualization, for all metrics! +- </p> +- <p> +- Netdata <b>zooms into the problems</b> by providing higher resolution information, compared to any other monitoring solution. +- </p> +- </div> +- <div class=grid-cell> +- <p class="quote"><i> +- The world goes real-time. +- <br/> <br/> +- High resolution metrics are required to effectively monitor and troubleshoot systems and applications, especially on virtual environments. +- </i></p> +- </div> +- </div> +- </div> +- <div> +- <a href="https://docs.netdata.cloud/docs/why-netdata/1s-granularity/">Learn more about high resolution metrics</a> +- </div> +-</div> +- +-<div class="site-section site-section-gray"> +- <div class=container> +- <div class="grid-title"> +- <h3><span class=star>★</span> Unlimited metrics</h3> +- </div> +- <div class=grid> +- <div class=grid-cell> +- <p> +- Use all the metrics, from all available sources! +- </p> +- <p> +- Netdata collects all the metrics native console tools do. It has been <b>designed to kill the console</b> for troubleshooting infrastructure slowdowns and outages. +- </p> +- </div> +- <div class=grid-cell> +- <p class="quote"><i> +- All metrics are important and all should be available when you need them. +- <br/> <br/> +- Filtering out most metrics is like reading a book by skipping most of its pages. +- </i></p> +- </div> +- </div> +- </div> +- <div> +- <a href="https://docs.netdata.cloud/docs/why-netdata/unlimited-metrics/">Learn more about unlimited metrics</a> +- </div> +-</div> +-<div class="site-section"> +- <div class=container> +- <div class="grid-title"> +- <h3><span class=star>★</span> Meaningful presentation</h3> +- </div> +- <div class=grid> +- <div class=grid-cell> +- <p> +- Explore all metrics in a meaningful, easy to understand way! +- </p> +- <p> +- Netdata engineers and experts on our community organize metrics in a meaningful way, so that you can learn and understand them right on the job, while troubleshooting issues of your infrastructure. +- </p> +- </div> +- <div class=grid-cell> +- <p class="quote"><i> +- Metrics are a lot more than name-value pairs over time. +- <br/> <br/> +- It is just not practical to require from all users to have a deep understanding of all metrics for monitoring their systems and applications. +- </i></p> +- </div> +- </div> +- </div> +- <div> +- <a href="https://docs.netdata.cloud/docs/why-netdata/meaningful-presentation/">Learn more about meaningful presentation</a> +- </div> +-</div> +- +-<div class="site-section site-section-gray"> +- <div class=container> +- <div class="grid-title"> +- <h3><span class=star>★</span> Immediate results</h3> +- </div> +- <div class=grid> +- <div class=grid-cell> +- <p> +- Install and use immediately! Get fully functional visualization and alarms, in just a couple of seconds after installation! +- </p> +- <p> +- Netdata <b>decouples your skills from your monitoring infrastructure</b>. +- No matter how skillful or novice you are, Netdata will apply all the community knowledge and expertise to your monitoring infrastructure. +- </p> +- </div> +- <div class=grid-cell> +- <p class="quote"><i> +- Most of our infrastructure is based on standardized systems and applications. +- <br/> <br/> +- It is a tremendous waste of time and effort, in a global scale, to require from all users to configure their infrastructure dashboards and alarms metric by metric. +- </i></p> +- </div> +- </div> +- </div> +- <div> +- <a href="https://docs.netdata.cloud/docs/why-netdata/immediate-results/">Learn more about immediate results</a> +- </div> +-</div> +- +-<div class="site-section site-section-dark"> +- <div class=container><h2>How it works</h2> +- <div style="padding-bottom: 1em"> +- <p> +- Netdata is a monitoring agent you install on all your systems: +- <br/> +- <b>physical servers</b>, <b>virtual servers</b>, <b>containers</b>, <b>IoT</b>. +- </p> +- <p> +- Netdata is lightweight, designed to permanently run on all systems without disrupting their core function. +- By default, it needs just 1% CPU of a single core, a few MB or RAM and no disk I/O at all. +- </p> +- <p> +- Each Netdata is (by default) autonomous, taking care of all the following. +- <br/>But all your Netdata are integrated into one large distributed application. +- </p> +- </div> +- <div class=grid> +- <div class=grid-cell><h3><span class=star>★</span> Collect</h3> +- <p> +- Netdata automatically detects data collection sources on the host it runs. +- It comes with hundreds of plugins for collecting system and application metrics, +- including databases, web servers, and commonly used application servers. +- <br/> <br/> +- Netdata is also a high performance, distributed <b>statsd server</b>, allowing custom +- application metrics to be collected and visualized. +- </p> +- </div> +- <div class=grid-cell><h3><span class=star>★</span> Check (alarms)</h3> +- <p> +- Each Netdata spawns a thread that examines the metrics as they get collected, +- evaluates pre-configured alarm expressions and triggers alarm notifications. +- <br/> <br/> +- Netdata comes with hundreds of alarms to detect common system and application issues, +- that are automatically attached to the collected metrics, +- supporting dozens of alarm notification integrations. +- </p> +- </div> +- <div class=grid-cell><h3><span class=star>★</span> Stream</h3> +- <p> +- Each Netdata can stream its metrics, in real-time, to any other Netdata. +- Streaming allows Netdata to be used in ephemeral nodes and containers in auto-scaled environments, +- but it also allows building Netdata hierarchies for aggregating the metrics of multiple Netdata nodes. +- </p> +- </div> +- <div class=grid-cell><h3><span class=star>★</span> Store</h3> +- <p> +- Each Netdata has its own internal metrics database. This database is optimized +- for minimal memory footprint, and due to its lockless design allows one writer +- and multiple readers per metric, concurrently, contributing significantly to +- the performance of Netdata. +- </p> +- </div> +- <div class=grid-cell><h3><span class=star>★</span> Archive</h3> +- <p> +- Netdata can archive its metrics to time-series databases (prometheus, graphite, opentsdb, json document dbs, etc) +- so that Netdata can be integrated to existing monitoring tool-chains. +- </p> +- </div> +- <div class=grid-cell><h3><span class=star>★</span> Visualize</h3> +- <p> +- The best part of Netdata is its visualization. Low latency, speedy and snazzy. +- <br/> <br/> +- Netdata dashboards are optimized for visual anomaly detection, a powerful tool to troubleshoot +- performance issues. +- </p> +- </div> +- </div> +- </div> +-</div> +- +-<div class="site-section"> +- +-</div> +- +- +-<div id="demosites" class="site-section site-section-dark"><h2>netdata live demo sites</h2> +- <div class="content"> +- <div class="container" style="text-align: center;"> +- +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//london.my-netdata.io" +- data-title="EU - London" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#558855" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//london.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoLondon><strong>Enter London!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//atlanta.my-netdata.io" +- data-title="US - Atlanta" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#AA5555" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//atlanta.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoAtlanta><strong>Enter Atlanta!</strong></a> +- <div class="mygause-donation"> +- Donated by CDN77.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//sanfrancisco.my-netdata.io" +- data-title="US - California" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#5555AA" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//sanfrancisco.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoSanfrancisco><strong>Enter California!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//toronto.my-netdata.io" +- data-title="Canada" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#885588" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//toronto.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoToronto><strong>Enter Canada!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <br/> <br/> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//frankfurt.my-netdata.io" +- data-title="EU - Germany" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#AAAA55" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//frankfurt.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoFrankfurt><strong>Enter Germany!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//newyork.my-netdata.io" +- data-title="US - New York" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#BB5533" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//newyork.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoNewYork><strong>Enter New York!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//singapore.my-netdata.io" +- data-title="Singapore" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#5588BB" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//singapore.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoSingapore><strong>Enter Singapore!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//bangalore.my-netdata.io" +- data-title="India" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#BB55BB" +- ></div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//bangalore.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoBangalore><strong>Enter India!</strong></a> +- <div class="mygause-donation"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div style="padding-top: 20px;"> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div style="padding-bottom: 20px; font-size: 10px; color: #676b70;"> +- <b>Israel</b> +- </div> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label2"> +- requests/s +- </div> +- <div class="mysparkline-overchart-value" id="octopuscs.requests.netdata" > +- </div> +- <div data-netdata="netdata.requests" +- data-dimensions="requests" +- data-host="//octopuscs.my-netdata.io" +- data-common-max="top-gauges" +- data-decimal-digits="0" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#4BFF91" +- data-show-value-of-requests-at="octopuscs.requests.netdata" +- ></div> +- </div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//octopuscs.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoOctopuscs><strong>Enter Israel!</strong></a> +- <div class="mygause-donation"> +- Donated by octopuscs.com +- </div> +- </div> +- </div> +- +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div style="padding-bottom: 20px; font-size: 10px; color: #676b70;"> +- <b>EU - Spain</b> +- </div> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label2"> +- requests/s +- </div> +- <div class="mysparkline-overchart-value" id="stackscale.requests.netdata" > +- </div> +- <div data-netdata="netdata.requests" +- data-dimensions="requests" +- data-host="//stackscale.my-netdata.io" +- data-common-max="top-gauges" +- data-decimal-digits="0" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#4B91FF" +- data-show-value-of-requests-at="stackscale.requests.netdata" +- ></div> +- </div> +- </div> +- <div class="mygauge-button"> +- <a class="btn btn-alt mygauge-legend-button" href=//stackscale.my-netdata.io/default.html data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=DemoStackScale><strong>Enter Madrid!</strong></a> +- <div class="mygause-donation"> +- Donated by stackscale.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- </div> +- </div> +- </div> +- </div> +- +- <div class="container" style="padding-top: 40px; text-align: center;"> +- Charts are coming from all servers, <b>in parallel</b>. +- <br/> +- The servers are <b>not aware</b> of this multi-server dashboard. +- </div> +- +- <div class="container" style="padding-top: 40px; padding-bottom: 40px; text-align: center;"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>EU - London</b> connected clients +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.connections.netdata" > +- </div> +- <div data-netdata="nginx_local.connections" +- data-dimensions="active" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="web-connections" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855" +- data-show-value-of-active-at="nginx_local.connections.netdata" +- ></div> +- </div> +- </div> +- +- <div class="container" style="padding-top: 0px; text-align: center;"> +- Each server is <b>not aware</b> of the other servers. +- <br/> +- But on this dashboard <b>they are one</b>! (hover on the chart above) +- </div> +- +- +- <!-- +- <div style="padding-top: 40px; color: #999;"> +- <small>We would love to show demos of IoT devices running netdata.<br/> +- If you can host at your DC an RPi or a Linux IoT, <a href="mailto:costa <at> tsaousis.gr?subject=I can host IoT for netdata&body=Hi Costa,%0D%0A%0D%0AI would love to host an IoT device to demo netdata on it.%0D%0A%0D%0A-- please tell me who you are and what infrastructure you have --%0D%0A-- Take into account I would need SSH access to it --%0D%0A-- You have to have a DC - a home is not good enough - sorry. --%0D%0A%0D%0AThanks!">contact me</a>.</small> +- </div> +- --> +- </div> +-</div> +- +-<div class=site-section><h2>Who uses netdata?</h2> +- <div class="content"> +- <div class="container" style="text-align: center;"> +- <p> +- Netdata is used by hundreds of thousands of users all over the world. +- <br/> <br/> +- Check our <a href="https://github.com/netdata/netdata/watchers">GitHub watchers</a> list. +- <br/> +- You will find people working for <b>Amazon</b>, <b>Atos</b>, <b>Baidu</b>, <b>Cisco Systems</b>, <b>Citrix</b>, +- <b>Deutsche Telekom</b>, <b>DigitalOcean</b>, <b>Elastic</b>, <b>EPAM Systems</b>, <b>Ericsson</b>, <b>Google</b>, +- <b>Groupon</b>, <b>Hortonworks</b>, <b>HP</b>, <b>Huawei</b>, <b>IBM</b>, <b>Microsoft</b>, <b>NewRelic</b>, +- <b>Nvidia</b>, <b>Red Hat</b>, <b>SAP</b>, <b>Selectel</b>, <b>TicketMaster</b>, <b>Vimeo</b>, and many more! +- </p> +- <small> +- The following figures come from users using the <a href="https://github.com/netdata/netdata/tree/master/registry" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=GlobalRegistry>netdata public global registry</a>.<br/>Counting since May 16th 2016. Actual figures may be a lot higher.<br/></small> +- <div class="container" style="padding-top: 40px; text-align: center; width: 30%; min-width: 220px; display: inline-block;"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- netdata <b>unique users</b> +- </div> +- <div class="mysparkline-overchart-value-center" id="netdata.registry_entries.persons.netdata" > +- </div> +- <div data-netdata="netdata.registry_entries" +- data-dimensions="persons" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855" +- data-show-value-of-persons-at="netdata.registry_entries.persons.netdata" +- ></div> +- </div> +- </div> +- <div class="container" style="padding-top: 40px; text-align: center; width: 30%; min-width: 220px; display: inline-block;"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- netdata <b>monitored servers</b> +- </div> +- <div class="mysparkline-overchart-value-center" id="netdata.registry_entries.machines.netdata" > +- </div> +- <div data-netdata="netdata.registry_entries" +- data-dimensions="machines" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855 #558855 #558855" +- data-show-value-of-machines-at="netdata.registry_entries.machines.netdata" +- ></div> +- </div> +- </div> +- <div class="container" style="padding-top: 40px; text-align: center; width: 30%; min-width: 220px; display: inline-block;"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- netdata <b>sessions served</b> +- </div> +- <div class="mysparkline-overchart-value-center" id="netdata.registry_sessions.sessions.netdata" > +- </div> +- <div data-netdata="netdata.registry_sessions" +- data-dimensions="sessions" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855 #558855 #558855" +- data-show-value-of-sessions-at="netdata.registry_sessions.sessions.netdata" +- ></div> +- </div> +- </div> +- <p> +- +- <!-- +- <embed src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_entries&dimensions=persons&label=user%20base&units=null&value_color=blue&precision=0&refresh=30&v42" type="image/svg+xml" height="20" /> +- <embed src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_entries&dimensions=machines&label=servers%20monitored&units=null&value_color=orange&precision=0&refresh=30&v42" type="image/svg+xml" height="20" /> +- <embed src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_sessions&label=sessions%20served&units=null&value_color=yellowgreen&precision=0&refresh=30&v42" type="image/svg+xml" height="20" /> +- <br/><i>(figures come from <a href="https://github.com/netdata/netdata/tree/master/registry" target="_blank">the public netdata registry</a> data, showing only installations that use this registry, counting since May 16th 2016)</i> +- <br/> +- --> +- </p> +- <p> +- <small> +- netdata can generate auto-refreshing <strong><a href="https://github.com/netdata/netdata/tree/master/web/api/badges#netdata-badges" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Badges>badges</a></strong>, like these: +- </small> +- <br/> +- <embed style="padding-top: 10px; padding-bottom: 25px;" src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_entries&dimensions=persons&after=-86400&options=unaligned&group=incremental-sum&label=new%20users%20today&units=null&value_color=blue&precision=0&refresh=60&v42" type="image/svg+xml" height="20" /> +- <embed style="padding-top: 10px; padding-bottom: 25px;" src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_entries&dimensions=machines&group=incremental-sum&after=-86400&options=unaligned&label=servers%20added%20today&units=null&value_color=orange&precision=0&refresh=60&v42" type="image/svg+xml" height="20" /> +- <embed style="padding-top: 10px; padding-bottom: 25px;" src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_sessions&after=-86400&group=incremental-sum&options=unaligned&label=sessions%20served%20today&units=null&value_color=yellowgreen&precision=0&refresh=60&v42" type="image/svg+xml" height="20" /> +- <br/> +- <small>These badges auto-refresh every minute.</small> +- </p> +- </div> +- <div class="container" style="text-align: center;"> +- <strong>netdata</strong> is featured at the <a href="https://octoverse.github.com/2016/" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Octoverse>GitHub's state of the Octoverse 2016</a> +- <div style="padding-top: 10px;"> +- <a href="https://octoverse.github.com/2016/" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=OctoverseImage> +- <img src="https://cloud.githubusercontent.com/assets/2662304/21743260/23ebe62c-d507-11e6-80c0-76b95f53e464.png" width="90%" style="border-radius: 4px; border: 1px solid #fff;"/> +- </a> +- </div> +- </div> +- <div class=cta-option> +- <a class="btn btn-download" href="https://docs.netdata.cloud/packaging/installer/" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=InstallAfterDemo><strong>Install netdata now</strong></a> +- </div> +- </div> +-</div> +-<div class=aside> +- <div class=container> +- <!-- Place this tag where you want the button to render. --> +- <a class="github-button" href="https://github.com/netdata/netdata/subscription" data-style="mega" data-show-count="true" aria-label="Watch netdata/netdata on GitHub"><img src="https://img.shields.io/github/watchers/netdata/netdata.svg?style=flat&label=Github%20Watchers"></a> +- <!-- Place this tag where you want the button to render. --> +- <a class="github-button" href="https://github.com/netdata/netdata" data-style="mega" data-show-count="true" aria-label="Star netdata/netdata on GitHub"><img src="https://img.shields.io/github/stars/netdata/netdata.svg?style=flat&label=Github%20Stars"></a> +- <!-- Place this tag where you want the button to render. --> +- <a class="github-button" href="https://github.com/netdata/netdata/fork" data-style="mega" data-show-count="true" aria-label="Fork netdata/netdata on GitHub"><img src="https://img.shields.io/github/forks/netdata/netdata.svg?style=flat&label=Github%20Repo%20Forks"></a> +- </div> +-</div> +- +-<!-- the footer --> +-<div class=site-footer role=contentinfo> +- <p> +- <div style="display: inline-block;"> +- <div style="vertical-align:top;display:inline-block; height: 34px;">twitter:</div> +- <div style="vertical-align:top;display:inline-block; height: 34px;"><a class=twitter-share-button href=https://twitter.com/share data-count=none data-lang=en data-via=linuxnetdata data-size=small data-text="Get control of your Linux servers. Simple. Effective. Awesome." data-url=https://my-netdata.io/ >Tweet</a></div> +- <div style="vertical-align:top;display:inline-block; height: 34px;"><a class=twitter-follow-button href=https://twitter.com/linuxnetdata data-show-count=false data-lang=en data-size=small>Follow @linuxnetdata</a></div> +- </div> +- <div style="display: inline-block;"> +- <div style="vertical-align:top;display:inline-block; height: 34px; padding-left: 10px;">facebook:</div> +- <div class="fb-like" data-href="https://my-netdata.io/" data-layout="button" data-action="like" data-show-faces="false" data-share="false" style="vertical-align:top;display:inline-block; height: 34px;"></div> +- <div class="fb-share-button" data-href="https://my-netdata.io/" data-layout="button" data-size="small" data-mobile-iframe="true"><a class="fb-xfbml-parse-ignore" target="_blank" href="https://www.facebook.com/sharer/sharer.php?u=https%3A%2F%2Fmy-netdata.io%2F&src=sdkpreparse" style="vertical-align:top;display:inline-block; height: 34px;">Share</a></div> +- <div class="fb-follow" data-href="https://www.facebook.com/linuxnetdata/" data-layout="standard" data-size="small" data-show-faces="false" data-colorscheme="dark" width="225" style="vertical-align:top;display:inline-block; height: 34px;"></div> +- </div> +- </p> +- <p> +- <strong>netdata</strong><br/> +- © Copyright 2018-2019, <a href="https://github.com/netdata" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=NetdataInc>Netdata</a><br/> +- © Copyright 2016-2018, <a href="https://github.com/ktsaou" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=CostaTsaousis>Costa Tsaousis</a><br/> +- Released under <a href="https://github.com/netdata/netdata/blob/master/LICENSE.md" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=License>GPL v3+</a><br/> +- </p> +- </p> +- <p style="padding-top: 20px;"> +- netdata has received significant contributions from:<br/> <br/> +- <a href="https://github.com/philwhineray" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Phil>Phil Whineray</a> (release management),<br/> +- <a href="https://github.com/alonbl" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Alon>Alon Bar-Lev</a> (autoconf and automake),<br/> +- <a href="https://github.com/titpetric" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=titpetric>Tit Petric</a> (docker image maintainer),<br/> +- <a href="https://github.com/paulfantom" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Pawel>Paweł Krupa</a> (python.d.plugin and modules),<br/> +- <a href="https://github.com/simonnagl" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=simonnagl>simonnagl</a> (disk plugin and more),<br/> +- <a href="https://github.com/fredericopissarra" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=Frederico>Frederico Lamberti Pissarra</a> (performance improvements)<br/> +- <a href="https://github.com/vlvkobal" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=VladimirKobal>Vladimir Kobal</a> (FreeBSD port)<br/> +- <a href="https://github.com/l2isbad" target="_blank" data-ga-category="Outbound links" data-ga-action="Nav click" data-ga-label=l2isbad>Ilya Mashchenko</a> (python plugin modules)<br/> +- <br/> +- and dozens more enthusiasts, engineers and professionals.<br/> <br/> +- </p> +- </p> +- Thank you! You are awesome! +- <p> +-</div> +-</body> +- +-<script> +- if(window.location.hostname != 'my-netdata.io' || window.location.protocol != 'https:') { +- var canonical = document.createElement('link'); +- canonical.rel = 'canonical'; +- canonical.href = 'https://my-netdata.io/'; +- document.head.appendChild(canonical); +- } +-</script> +- +-<script>!function (t, e) { +- "use strict"; +- function a(t, n) { +- return t.hasAttribute(n) === !0 ? t : t.parentNode !== r.body ? a(t.parentNode, n) : e +- } +- +- function n(n) { +- var o, i, r, c, g, u = a(n.target, "data-ga-action"), l = !1; +- u !== e && (o = u.getAttribute("data-ga-action") || e, i = u.getAttribute("data-ga-category") || e, r = u.getAttribute("data-ga-label") || e, c = u.getAttribute("href"), g = parseInt(u.getAttribute("data-ga-value"), 10) || e, ga !== e && i !== e && o !== e && (n.preventDefault(), "Download" !== i && n.ctrlKey !== !0 && n.metaKey !== !0 && 2 !== n.which || (l = !0, t.open(c)), function (a) { +- var n; +- ga("send", "event", i, o, r, g, { +- hitCallback: function () { +- l === !1 && (n !== e && clearTimeout(n), t.location = a) +- } +- }), n = setTimeout(function () { +- l === !1 && (t.location.href = a) +- }, 1e3) +- }(c))) +- } +- +- function o() { +- !function (t, e, a, n, o, i) { +- t.GoogleAnalyticsObject = n, t[n] || (t[n] = function () { +- (t[n].q = t[n].q || []).push(arguments) +- }), t[n].l = +new Date, o = e.createElement(a), i = e.getElementsByTagName(a)[0], o.src = "//www.google-analytics.com/analytics.js", i.parentNode.insertBefore(o, i) +- }(t, r, "script", "ga"), ga("create", "UA-64295674-3", "auto"), ga("send", "pageview", "/site"+window.location.pathname), t.document.addEventListener("click", n) +- } +- +- function i() { +- !function (t, e, a) { +- var n, o = t.getElementsByTagName(e)[0]; +- t.getElementById(a) || (n = t.createElement(e), n.id = a, n.src = "//platform.twitter.com/widgets.js", o.parentNode.insertBefore(n, o)) +- }(r, "script", "twitter-wjs") +- } +- +- var r = t.document; +- o(), t.onload = i +-}(window)</script> +- +-<!-- facebook sdk --> +-<div id="fb-root"></div> +-<script> +- window.fbAsyncInit = function() { +- FB.init({ +- appId : '1200089276712916', +- xfbml : true, +- version : 'v2.8' +- }); +- }; +- +- (function(d, s, id){ +- var js, fjs = d.getElementsByTagName(s)[0]; +- if (d.getElementById(id)) {return;} +- js = d.createElement(s); js.id = id; +- js.src = "//connect.facebook.net/en_US/sdk.js"; +- fjs.parentNode.insertBefore(js, fjs); +- }(document, 'script', 'facebook-jssdk')); +-</script> +- +-<script> +- var allTitles = [ +- 'Get control<br/>of your Linux servers' +- , 'Get control<br/>of your FreeBSD servers' +- , 'Monitor<br/>your containers' +- , 'Monitor<br/>your virtual machines' +- , 'Monitor<br/>your web servers' +- , 'Monitor<br/>your databases' +- , 'Monitor<br/>your applications' +- , 'Monitor<br/>your SNMP devices' +- , 'Monitor<br/>your IoT devices' +- , 'Monitor<br/>your MacOS systems' +- ]; +- var lastTitle = -1; +- +- function updateTitle(){ +- lastTitle++; +- if(lastTitle >= allTitles.length) +- lastTitle = 0; +- +- var os = document.getElementsByClassName('title'); +- var len = os.length; +- while (len--) { +- var el = os[len]; +- el.innerHTML = allTitles[lastTitle]; +- el.classList.add('titlefadein'); +- } +- +- setTimeout(function() { +- var os = document.getElementsByClassName('title'); +- var len = os.length; +- while (len--) +- os[len].classList.remove('titlefadein'); +- +- }, 5750); +- setTimeout(updateTitle, 6000); +- } +- //updateTitle(); +-</script> +- +-<!-- Start of HubSpot Embed Code --> +-<script type="text/javascript" id="hs-script-loader" async defer src="//js.hs-scripts.com/4567453.js"></script> +-<!-- End of HubSpot Embed Code --> +diff --git a/web/gui/demosites2.html b/web/gui/demosites2.html +deleted file mode 100644 +index fe35cfb6..00000000 +--- a/web/gui/demosites2.html ++++ /dev/null +@@ -1,1112 +0,0 @@ +-<!DOCTYPE html> +-<!-- SPDX-License-Identifier: GPL-3.0-or-later --> +-<html lang="en"> +-<head> +- <title>NetData - Real-time performance monitoring, done right!</title> +- <meta name="application-name" content="netdata"> +- +- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +- <meta charset="utf-8"> +- <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> +- <meta name="viewport" content="width=device-width, initial-scale=1"> +- <meta name="apple-mobile-web-app-capable" content="yes"> +- <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"> +- +- <meta property="og:locale" content="en_US" /> +- <meta property="og:image" content="https://cloud.githubusercontent.com/assets/2662304/22945737/e98cd0c6-f2fd-11e6-96f1-5501934b0955.png"/> +- <meta property="og:url" content="http://my-netdata.io/"/> +- <meta property="og:type" content="website"/> +- <meta property="og:site_name" content="netdata"/> +- <meta property="og:title" content="netdata - real-time performance monitoring, done right!"/> +- <meta property="og:description" content="Stunning real-time dashboards, blazingly fast and extremely interactive. Zero configuration, zero dependencies, zero maintenance." /> +-</head> +- +-<script> +- // --- OPTIONS FOR THE DASHBOARD -- +- +- // this section has to appear before loading dashboard.js +- +- // Select a theme. +- // uncomment on of the two themes: +- +- // var netdataTheme = 'default'; // this is white +- var netdataTheme = 'slate'; // this is dark +- +- +- // Set the default netdata server. +- // on charts without a 'data-host', this one will be used. +- // the default is the server that dashboard.js is downloaded from. +- +- // var netdataServer = 'http://my.server:19999/'; +- </script> +- +- <!-- +- --- LOAD dashboard.js --- +- +- to host this HTML file on your web server, +- you have to load dashboard.js from the netdata server. +- +- So, pick one the two below +- If you pick the first, set the server name/IP. +- +- The second assumes you host this file on /usr/share/netdata/web +- and that you have chown it to be owned by netdata:netdata +- --> +- <!-- <script type="text/javascript" src="http://my.server:19999/dashboard.js"></script> --> +- <script type="text/javascript" src="dashboard.js?v20190902-0"></script> +- +- <script> +- // --- OPTIONS FOR THE CHARTS -- +- +- // destroy charts not shown (lowers memory on the browsers) +- // set this to 'true' to destroy, 'false' to hide the charts +- NETDATA.options.current.destroy_on_hide = false; +- +- // set this to false, to always show all dimensions +- NETDATA.options.current.eliminate_zero_dimensions = true; +- +- // set this to false, to lower the pressure on the browser +- NETDATA.options.current.concurrent_refreshes = true; +- +- // if you need to support slow mobile phones, set this to false +- NETDATA.options.current.parallel_refresher = true; +- +- // set this to false, to always update the charts, even if focus is lost +- NETDATA.options.current.stop_updates_when_focus_is_lost = true; +- +- // since we have many servers and limited sockets, +- // abort ajax calls when we scroll +- NETDATA.options.current.abort_ajax_on_scroll = true; +-</script> +-<style> +- body { +- font-size: 1vw; +- } +- +- .mysparkline { +- position: relative; +- display: inline-block; +- min-height: 50px; +- width: 100%; +- height: 7vmax; +- text-align: left; +- } +- +- .mysparkline-overchart-label { +- position: absolute; +- display: block; +- top: 0; +- left: 10px; +- bottom: 0; +- right: 0; +- font-size: 1vmax; +- z-index: 1; +- } +- +- .mysparkline-overchart-value { +- position: absolute; +- display: block; +- top: 1.1vmax; +- left: 10px; +- bottom: 0; +- right: 0; +- font-size: 5vmax; +- z-index: 2; +- text-shadow: #333 0px 0px 2px; +- } +- +- .myfullchart { +- position: relative; +- display: inline-block; +- width: 100%; +- height: 12vmax; +- min-height: 150px; +- text-align: left; +- } +- +- .mygauge-combo { +- display: inline-block; +- } +- +- .mygauge { +- position: relative; +- display: block; +- width: 18vw; +- height: 11vw; +- } +- +- .mygauge-button { +- display: block; +- } +- +- .mytitle { +- padding-top: 6vw; +- padding-bottom: 1vw; +- text-align: center; +- font-size: 2.4vw; +- } +- +- .mysubtitle { +- padding-top: 2vw; +- padding-bottom: 1vw; +- text-align: center; +- font-size: 1.8vw; +- } +- +- .mycontent { +- text-align: center; +- font-size: 1.5vw; +- } +- +- @media only screen and (min-width : 992px) { +- .container { +- width: 80%; +- } +- } +- @media only screen and (max-width : 992px) { +- .container { +- width: 100%; +- } +- } +-</style> +- +-<body style="text-align: center; background-color: #272b30;"> +- +-<div class="container"> +- +- <div style="text-align: center; font-size: 13vw; height: 14vw;"> +- <b>netdata</b> +- </div> +- <div style="text-align: center; font-size: 2vw; height: 2.5vw;"> +- real-time performance monitoring +- </div> +- <div style="width:80%; text-align: right; font-size: 2.7vw;"> +- <strong>scaled out</strong>! +- </div> +- <div class="mytitle"> +- pick a <b>netdata</b> demo server +- </div> +- <div class="mycontent"> +- these demo servers show what you will get by installing <b>netdata</b> +- </div> +- +- <div style="width: 100%; text-align: center; padding-top: 2vw;"> +- <div style="width: 100%; text-align: center;"> +- +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//london.my-netdata.io" +- data-title="EU - London" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#558855" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//london.my-netdata.io/default.html'" style="font-size: 1.0vw;">Enter London!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//atlanta.my-netdata.io" +- data-title="US - Atlanta" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#AA5555" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//atlanta.my-netdata.io/default.html'" style="font-size: 1.0vw;">Enter Atlanta!</button> +- <div style="font-size: 0.8vw;"> +- Donated by CDN77.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//sanfrancisco.netdata.rocks" +- data-title="US - California" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#5555AA" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//sanfrancisco.netdata.rocks/default.html'" style="font-size: 1.0vw;">Enter California!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//toronto.netdata.rocks" +- data-title="Canada" +- data-chart-library="gauge" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="100%" +- data-after="-300" +- data-points="300" +- data-colors="#885588" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//toronto.netdata.rocks/default.html'" style="font-size: 1.0vw;">Enter Canada!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <br/> <br/> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//frankfurt.netdata.rocks" +- data-title="EU - Germany" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#AAAA55" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//frankfurt.netdata.rocks/default.html'" style="font-size: 1.0vw;">Enter Germany!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//newyork.netdata.rocks" +- data-title="US - New York" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#BB5533" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//newyork.netdata.rocks/default.html'" style="font-size: 1.0vw;">Enter New York!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//singapore.netdata.rocks" +- data-title="Singapore" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#5588BB" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//singapore.netdata.rocks/default.html'" style="font-size: 1.0vw;">Enter Singapore!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- <div class="mygauge-combo"> +- <div class="mygauge"> +- <div data-netdata="netdata.requests" +- data-host="//bangalore.netdata.rocks" +- data-title="India" +- data-chart-library="easypiechart" +- data-decimal-digits="0" +- data-common-max="top-gauges" +- data-width="75%" +- data-after="-300" +- data-points="300" +- data-colors="#BB55BB" +- ></div> +- </div> +- <div class="mygauge-button"> +- <br/> <br/> +- <button type="button" class="btn btn-default" data-toggle="button" aria-pressed="false" autocomplete="off" onclick="window.location='//bangalore.netdata.rocks/default.html'" style="font-size: 1.0vw;">Enter India!</button> +- <div style="font-size: 0.8vw;"> +- Donated by DigitalOcean.com +- </div> +- </div> +- </div> +- </div> +- </div> +- +- <div class="mytitle"> +- this page is a custom <b>netdata</b> dashboard +- </div> +- <div class="mycontent"> +- charts are coming from 8 servers, in parallel +- <br/> +- the servers are not aware of this multi-server dashboard, +- <br/> +- each server is not aware of the other servers, +- <br/> +- but on this dashboard <b>they are one</b>! +- </div> +- <div style="padding-top: 1vw; width: 100%; text-align: center; font-size: 1.5vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> +- hover on a chart below, or drag it to show the past - <b>the others will follow</b>! +- <br/> +- double click on a chart to reset them all +- </div> +- +- <div class="mytitle"> +- our <code>nginx</code> performance +- </div> +- <div class="mycontent"> +- (we proxy netdata through nginx, on the demo sites) +- </div> +- +- <!-- Nav tabs --> +- <ul class="nav nav-tabs" role="tablist" style="padding-top: 1vw;"> +- <li role="presentation" class="active"><a href="#nginx_requests" aria-controls="nginx_requests" role="tab" data-toggle="tab">Requests</a></li> +- <li role="presentation"><a href="#nginx_connections" aria-controls="nginx_connections" role="tab" data-toggle="tab">Connections</a></li> +- </ul> +- +- <!-- Tab panes --> +- <div class="tab-content"> +- <div role="tabpanel" class="tab-pane active" id="nginx_requests"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>EU - London</b> web requests/s +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.requests.netdata" > +- </div> +- <div data-netdata="nginx_local.requests" +- data-dimensions="requests" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="web-requests" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855" +- data-show-value-of-requests-at="nginx_local.requests.netdata" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - Atlanta</b> web requests/s +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.requests.netdata2" > +- </div> +- <div data-netdata="nginx_local.requests" +- data-dimensions="requests" +- data-host="//atlanta.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="web-requests" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#AA5555" +- data-show-value-of-requests-at="nginx_local.requests.netdata2" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - California</b> web requests/s +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.requests.netdata3" > +- </div> +- <div data-netdata="nginx_local.requests" +- data-dimensions="requests" +- data-host="//sanfrancisco.netdata.rocks" +- data-decimal-digits="0" +- data-common-max="web-requests" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#5555AA" +- data-show-value-of-requests-at="nginx_local.requests.netdata3" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>Canada</b> web requests/s +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.requests.netdata4" > +- </div> +- <div data-netdata="nginx_local.requests" +- data-dimensions="requests" +- data-host="//toronto.netdata.rocks" +- data-decimal-digits="0" +- data-common-max="web-requests" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885588" +- data-show-value-of-requests-at="nginx_local.requests.netdata4" +- ></div> +- </div> +- </div> +- +- <div role="tabpanel" class="tab-pane" id="nginx_connections"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>EU - London</b> active connections +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.connections.netdata1" > +- </div> +- <div data-netdata="nginx_local.connections" +- data-dimensions="active" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="web-connections" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855" +- data-show-value-of-active-at="nginx_local.connections.netdata1" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - Atlanta</b> active connections +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.connections.netdata2" > +- </div> +- <div data-netdata="nginx_local.connections" +- data-dimensions="active" +- data-host="//atlanta.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="web-connections" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#AA5555" +- data-show-value-of-active-at="nginx_local.connections.netdata2" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - California</b> active connections +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.connections.netdata3" > +- </div> +- <div data-netdata="nginx_local.connections" +- data-dimensions="active" +- data-host="//sanfrancisco.netdata.rocks" +- data-decimal-digits="0" +- data-common-max="web-connections" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#5555AA" +- data-show-value-of-active-at="nginx_local.connections.netdata3" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>Canada</b> active connections +- </div> +- <div class="mysparkline-overchart-value" id="nginx_local.connections.netdata4" > +- </div> +- <div data-netdata="nginx_local.connections" +- data-dimensions="active" +- data-host="//toronto.netdata.rocks" +- data-decimal-digits="0" +- data-common-max="web-connections" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885588" +- data-show-value-of-active-at="nginx_local.connections.netdata4" +- ></div> +- </div> +- </div> +- </div> +- +- <div style="width: 100%; text-align: right; font-size: 1vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> these charts are draggable and touchable, double click them to reset them +- </div> +- +- +- <div class="mytitle"> +- bandwidth consumption on the demo sites +- </div> +- <div class="mycontent"> +- Linux QoS is configured by <a href="https://github.com/netdata/netdata/tree/master/collectors/tc.plugin#tcplugin">FireQOS</a> +- </div> +- +- <!-- Nav tabs --> +- <ul class="nav nav-tabs" role="tablist" style="padding-top: 1vw;"> +- <li role="presentation" class="active"><a href="#outbout" aria-controls="outbout" role="tab" data-toggle="tab">Outbound</a></li> +- <li role="presentation"><a href="#inbound" aria-controls="inbound" role="tab" data-toggle="tab">Inbound</a></li> +- </ul> +- +- <!-- Tab panes --> +- <div class="tab-content"> +- <div role="tabpanel" class="tab-pane active" id="outbout"> +- <div class="myfullchart"> +- <div data-netdata="tc.world_out" +- data-host="//london.my-netdata.io" +- data-common-max="tc-world-out" +- data-chart-library="dygraph" +- data-title="EU - London, traffic we send per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="tc.world_out" +- data-host="//atlanta.my-netdata.io" +- data-chart-library="dygraph" +- data-common-max="tc-world-out" +- data-title="US - Atlanta, traffic we send per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="tc.world_out" +- data-host="//sanfrancisco.netdata.rocks" +- data-chart-library="dygraph" +- data-common-max="tc-world-out" +- data-title="US - California, traffic we send per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="tc.world_out" +- data-host="//toronto.netdata.rocks" +- data-chart-library="dygraph" +- data-common-max="tc-world-out" +- data-title="Canada, traffic we send per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- </div> +- </div> +- +- <div role="tabpanel" class="tab-pane" id="inbound"> +- <div class="myfullchart"> +- <div data-netdata="tc.world_in" +- data-host="//london.my-netdata.io" +- data-common-max="tc-world-in" +- data-chart-library="dygraph" +- data-title="EU - London, traffic we receive per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="tc.world_in" +- data-host="//atlanta.my-netdata.io" +- data-common-max="tc-world-in" +- data-chart-library="dygraph" +- data-title="US - Atlanta, traffic we receive per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="tc.world_in" +- data-host="//sanfrancisco.netdata.rocks" +- data-common-max="tc-world-in" +- data-chart-library="dygraph" +- data-title="US - California, traffic we receive per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="tc.world_in" +- data-host="//toronto.netdata.rocks" +- data-common-max="tc-world-in" +- data-chart-library="dygraph" +- data-title="Canada, traffic we receive per service" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- ></div> +- </div> +- </div> +- </div> +- <div style="width: 100%; text-align: right; font-size: 1vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> <i>these legends are interactive and the charts are resizable here ^^^</i> +- </div> +- +- <div class="mytitle"> +- DDoS protection performance on the demo sites +- </div> +- <div class="mycontent"> +- iptables SYNPROXY configured by <a href="https://github.com/netdata/netdata/blob/master/collectors/proc.plugin/README.md#linux-anti-ddos">FireHOL</a> +- </div> +- +- <div style="padding-top: 4vw; width: 100%; text-align: center; font-size: 1.5vw;"> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>EU - London</b>, TCP SYN packets/s received +- </div> +- <div class="mysparkline-overchart-value" id="netfilter.synproxy_syn_received.netdata1" > +- </div> +- <div data-netdata="netfilter.synproxy_syn_received" +- data-dimensions="received" +- data-host="//london.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="synproxy-in" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855" +- data-show-value-of-received-at="netfilter.synproxy_syn_received.netdata1" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - Atlanta</b>, TCP SYN packets/s received +- </div> +- <div class="mysparkline-overchart-value" id="netfilter.synproxy_syn_received.netdata2" > +- </div> +- <div data-netdata="netfilter.synproxy_syn_received" +- data-dimensions="received" +- data-host="//atlanta.my-netdata.io" +- data-decimal-digits="0" +- data-common-max="synproxy-in" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885555" +- data-show-value-of-received-at="netfilter.synproxy_syn_received.netdata2" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - California</b>, TCP SYN packets/s received +- </div> +- <div class="mysparkline-overchart-value" id="netfilter.synproxy_syn_received.netdata3" > +- </div> +- <div data-netdata="netfilter.synproxy_syn_received" +- data-dimensions="received" +- data-host="//sanfrancisco.netdata.rocks" +- data-decimal-digits="0" +- data-common-max="synproxy-in" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#555588" +- data-show-value-of-received-at="netfilter.synproxy_syn_received.netdata3" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>Canada</b>, TCP SYN packets/s received +- </div> +- <div class="mysparkline-overchart-value" id="netfilter.synproxy_syn_received.netdata4" > +- </div> +- <div data-netdata="netfilter.synproxy_syn_received" +- data-dimensions="received" +- data-host="//toronto.netdata.rocks" +- data-decimal-digits="0" +- data-common-max="synproxy-in" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885588" +- data-show-value-of-received-at="netfilter.synproxy_syn_received.netdata4" +- ></div> +- </div> +- </div> +- <div style="width: 100%; text-align: right; font-size: 1vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> <i>did you notice the decimal numbers? +- <br/>netdata interpolates collected values at second boundaries, with nanosecond detail!</i> +- </div> +- +- +- <div class="mytitle"> +- CPU Utilization of the demo sites +- </div> +- +- <div style="padding-top: 1vw;"> +- <div class="myfullchart"> +- <div data-netdata="system.cpu" +- data-host="//london.my-netdata.io" +- data-chart-library="dygraph" +- data-title="EU - London, CPU Usage" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-dygraph-valuerange="[0, 100]" +- ></div> +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="system.cpu" +- data-host="//atlanta.my-netdata.io" +- data-chart-library="dygraph" +- data-title="US - Atlanta, CPU Usage" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-dygraph-valuerange="[0, 100]" +- ></div> +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="system.cpu" +- data-host="//sanfrancisco.netdata.rocks" +- data-chart-library="dygraph" +- data-title="US - California, CPU Usage" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-dygraph-valuerange="[0, 100]" +- ></div> +- </div> +- +- <div class="myfullchart"> +- <div data-netdata="system.cpu" +- data-host="//toronto.netdata.rocks" +- data-chart-library="dygraph" +- data-title="Canada, CPU Usage" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-dygraph-valuerange="[0, 100]" +- ></div> +- </div> +- </div> +- <div style="width: 100%; text-align: right; font-size: 1vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> <i>what is using so much CPU? +- <br/>The site <a href="//iplists.firehol.org/">iplists.firehol.org</a> is maintained by FireHOL - the CPU is used for comparing security IP Lists.</i> +- </div> +- +- <div class="mytitle"> +- Netdata performance +- </div> +- <div class="mycontent"> +- netdata monitors <b>users</b>, <b>user groups</b>, <b>applications (process trees)</b> +- <br/> +- <b>containers</b> (<code>lxc</code>, <code>docker</code>, etc.) and SNMP devices. +- </div> +- +- <!-- Nav tabs --> +- <ul class="nav nav-tabs" role="tablist" style="padding-top: 1vw;"> +- <li role="presentation" class="active"><a href="#netdata_cpu" aria-controls="netdata_cpu" role="tab" data-toggle="tab">CPU</a></li> +- <li role="presentation"><a href="#netdata_avgtime" aria-controls="netdata_avgtime" role="tab" data-toggle="tab">Average Response Time</a></li> +- </ul> +- +- <!-- Tab panes --> +- <div class="tab-content"> +- <div role="tabpanel" class="tab-pane active" id="netdata_cpu"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>EU - London</b>, CPU % of a single core +- </div> +- <div class="mysparkline-overchart-value" id="users.cpu.netdata1" > +- </div> +- <div data-netdata="apps.cpu" +- data-dimensions="netdata" +- data-common-max="users-cpu" +- data-decimal-digits="1" +- data-host="//london.my-netdata.io" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855" +- data-show-value-of-netdata-at="users.cpu.netdata1" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - Atlanta</b>, CPU % of a single core +- </div> +- <div class="mysparkline-overchart-value" id="users.cpu.netdata2" > +- </div> +- <div data-netdata="apps.cpu" +- data-dimensions="netdata" +- data-common-max="users-cpu" +- data-decimal-digits="1" +- data-host="//atlanta.my-netdata.io" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885555" +- data-show-value-of-netdata-at="users.cpu.netdata2" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - California</b>, CPU % of a single core +- </div> +- <div class="mysparkline-overchart-value" id="users.cpu.netdata3" > +- </div> +- <div data-netdata="apps.cpu" +- data-dimensions="netdata" +- data-common-max="users-cpu" +- data-decimal-digits="1" +- data-host="//sanfrancisco.netdata.rocks" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#555588" +- data-show-value-of-netdata-at="users.cpu.netdata3" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>Toronto</b>, CPU % of a single core +- </div> +- <div class="mysparkline-overchart-value" id="users.cpu.netdata4" > +- </div> +- <div data-netdata="apps.cpu" +- data-dimensions="netdata" +- data-common-max="users-cpu" +- data-decimal-digits="1" +- data-host="//toronto.netdata.rocks" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885588" +- data-show-value-of-netdata-at="users.cpu.netdata4" +- ></div> +- </div> +- +- <div style="width: 100%; text-align: right; font-size: 1vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> <i>this utilization is about the whole netdata process tree and the percentage is of <b>a single core</b>! +- <br/>including <b>BASH</b> plugins (it monitors <code>mysql</code> on the demo sites), <b>node.js</b> plugins (it monitors <code>bind9</code> on the demo sites), etc. +- <br/>and including the chart refreshes for the dashboards of all viewers.</i> +- </div> +- </div> +- +- <div role="tabpanel" class="tab-pane" id="netdata_avgtime"> +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>EU - London</b>, API average response time in milliseconds +- </div> +- <div class="mysparkline-overchart-value" id="netdata.response_time1" > +- </div> +- <div data-netdata="netdata.response_time" +- data-host="//london.my-netdata.io" +- data-common-max="netdata-response-time" +- data-decimal-digits="1" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#558855 #356835" +- data-show-value-of-average-at="netdata.response_time1" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - Atlanta</b>, API average response time in milliseconds +- </div> +- <div class="mysparkline-overchart-value" id="netdata.response_time2" > +- </div> +- <div data-netdata="netdata.response_time" +- data-host="//atlanta.my-netdata.io" +- data-common-max="netdata-response-time" +- data-decimal-digits="1" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885555 #683535" +- data-show-value-of-average-at="netdata.response_time2" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>US - California</b>, API average response time in milliseconds +- </div> +- <div class="mysparkline-overchart-value" id="netdata.response_time3" > +- </div> +- <div data-netdata="netdata.response_time" +- data-host="//sanfrancisco.netdata.rocks" +- data-common-max="netdata-response-time" +- data-decimal-digits="1" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#555588 #353568" +- data-show-value-of-average-at="netdata.response_time3" +- ></div> +- </div> +- +- <div class="mysparkline"> +- <div class="mysparkline-overchart-label"> +- <b>Canada</b>, API average response time in milliseconds +- </div> +- <div class="mysparkline-overchart-value" id="netdata.response_time4" > +- </div> +- <div data-netdata="netdata.response_time" +- data-host="//toronto.netdata.rocks" +- data-decimal-digits="1" +- data-common-max="netdata-response-time" +- data-chart-library="dygraph" +- data-dygraph-theme="sparkline" +- data-dygraph-type="area" +- data-width="100%" +- data-height="100%" +- data-after="-300" +- data-colors="#885588 #683568" +- data-show-value-of-average-at="netdata.response_time4" +- ></div> +- </div> +- +- <div style="width: 100%; text-align: right; font-size: 1vw;"> +- <i class="fa fa-comment" aria-hidden="true"></i> <i>netdata is really <b>fast</b> (the values are milliseconds!) +- <br/> +- These values include everything, from the reception of the first byte to the dispatch of the last, including gzip compression. +- <br/> +- Values above 2-3ms are usually chart refreshes of charts with several dimensions, charts with very long durations (zoomed out), or file transfers. +- </i> +- </div> +- </div> +- </div> +- +- <div style="padding-top: 6vw; width: 100%; text-align: center; font-size: 2vw;"> +- want to know more? +- <br/> +- jump to <a href="https://github.com/netdata/netdata/">the netdata page at github</a> +- <br/> +- it needs just 3 mins to be installed on your servers! +- <br/> +- +- </div> +-</div> +-</body> +-<script> +- // google analytics when this is used for the home page of the demo sites +- // you don't need this if you customize this dashboard for your needs +- setTimeout(function() { +- (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ +- (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), +- m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) +- })(window,document,'script','https://www.google-analytics.com/analytics.js','ga'); +- +- ga('create', 'UA-64295674-3', 'auto'); +- ga('send', 'pageview'); +- }, 2000); +-</script> +-</html> +diff --git a/web/gui/goto-host-from-alarm.html b/web/gui/goto-host-from-alarm.html +index 7d12f848..af9db7ea 100644 +--- a/web/gui/goto-host-from-alarm.html ++++ b/web/gui/goto-host-from-alarm.html +@@ -2,13 +2,6 @@ + <!-- SPDX-License-Identifier: GPL-3.0-or-later --> + <html lang="en"> + <head> +- <script>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start': +- new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0], +- j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src= +- 'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f); +- })(window,document,'script','dataLayer','GTM-N6CBMJD'); +- dataLayer.push({"anonymous_statistics" : "false"}); +- </script> + <title>Goto a host you know...</title> + <meta name="application-name" content="netdata"> + <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +diff --git a/web/gui/index.html b/web/gui/index.html +index d3099101..47baa548 100644 +--- a/web/gui/index.html ++++ b/web/gui/index.html +@@ -17,22 +17,6 @@ + + <link rel="icon" href="" /> + +- <meta property="og:locale" content="en_US" /> +- <meta property="og:url" content="https://my-netdata.io" /> +- <meta property="og:type" content="website" /> +- <meta property="og:site_name" content="netdata"/> +- <meta property="og:title" content="Get control of your Linux Servers. Simple. Effective. Awesome." /> +- <meta property="og:description" content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms." /> +- <meta property="og:image" content="https://cloud.githubusercontent.com/assets/2662304/22945737/e98cd0c6-f2fd-11e6-96f1-5501934b0955.png" /> +- <meta property="og:image:type" content="image/png" /> +- <meta property="fb:app_id" content="1200089276712916" /> +- +- <meta name="twitter:card" content="summary" /> +- <meta name="twitter:site" content="@linuxnetdata" /> +- <meta name="twitter:title" content="Get control of your Linux Servers. Simple. Effective. Awesome." /> +- <meta name="twitter:description" content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms." /> +- <meta name="twitter:image" content="https://cloud.githubusercontent.com/assets/2662304/14092712/93b039ea-f551-11e5-822c-beadbf2b2a2e.gif" /> +- + <script src="main.js?v20190905-0"></script> + </head> + +@@ -90,13 +74,9 @@ + </div> + <nav class="collapse navbar-collapse navbar-right" role="navigation"> + <ul class="nav navbar-nav"> +- <li title="Nodes view" data-toggle="tooltip" data-placement="bottom"><a onclick="openAuthenticatedUrl('console.html');" class="btn" target="_blank"><i class="fas fa-tv"></i> <span class="hidden-sm hidden-md">Nodes<sup class="beta"> beta</sup></span></a></li> + <li id="alarmsButton" title="check the health monitoring alarms and their log" data-toggle="tooltip" data-placement="bottom"><a href="#" class="btn" data-toggle="modal" data-target="#alarmsModal"><i class="fas fa-bell"></i> <span class="hidden-sm hidden-md">Alarms </span><span id="alarms_count_badge" class="badge"></span></a></li> + <li title="change dashboard settings" data-toggle="tooltip" data-placement="bottom"><a href="#" class="btn" data-toggle="modal" data-target="#optionsModal"><i class="fas fa-cog"></i> <span class="hidden-sm hidden-md">Settings</span></a></li> +- <li title="check for netdata updates<br/>you should keep your netdata updated" data-toggle="tooltip" data-placement="bottom" class="hidden-sm" id="updateButton"><a href="#" class="btn" data-toggle="modal" data-target="#updateModal"><i class="fas fa-cloud-download-alt"></i> <span class="hidden-sm hidden-md">Update </span><span id="update_badge" class="badge"></span></a></li> + <li title="the netdata wiki home at github<br/>remember to <b>give netdata a <i class="fas fa-star"></i></b> !" data-toggle="tooltip" data-placement="bottom" class="hidden-xs hidden-sm hidden-md"><a href="https://github.com/netdata/netdata" class="btn" target="_blank"><i class="fab fa-github"></i></a></li> +- <li title="follow netdata on twitter" data-toggle="tooltip" data-placement="bottom" class="hidden-xs hidden-sm hidden-md"><a href="https://twitter.com/linuxnetdata" class="btn" target="_blank"><i class="fab fa-twitter"></i></a></li> +- <li title="like netdata on facebook" data-toggle="tooltip" data-placement="bottom" class="hidden-xs hidden-sm hidden-md"><a href="https://www.facebook.com/linuxnetdata/" class="btn" target="_blank"><i class="fab fa-facebook"></i></a></li> + <li title="import / load a netdata snapshot" data-toggle="tooltip" data-placement="bottom" id="loadButton"><a href="#" class="btn" data-toggle="modal" data-target="#loadSnapshotModal"><i class="fas fa-download"></i> <span class="hidden-sm hidden-md hidden-lg">Import</span></a></li> + <li title="export / save a netdata snapshot" data-toggle="tooltip" data-placement="bottom" id="saveButton"><a href="#" class="btn" data-toggle="modal" data-target="#saveSnapshotModal"><i class="fas fa-upload"></i> <span class="hidden-sm hidden-md hidden-lg">Export</span></a></li> + <li title="print this dashboard to PDF" data-toggle="tooltip" data-placement="bottom" id="printButton"><a href="#" class="btn" data-toggle="modal" data-target="#printPreflightModal"><i class="fas fa-print"></i> <span class="hidden-sm hidden-md hidden-lg">Print</span></a></li> +@@ -109,17 +89,6 @@ + <div class="navbar-highlight"> + <div id="navbar-highlight-content" class="navbar-highlight-content"></div> + </div> +- +- <div id="sign-in-banner" style="display: none"> +- <div class="container"> +- Like what you see? +- <strong><a href="#" class="__link" onclick="signInDidClick(event); return false">Sign in</a> +- to experience the full-range of netdata capabilities!</strong> +- <div class="__close" onclick="closeSignInBannerDidClick(event)"> +- Close <i class="fas fa-times"></i> +- </div> +- </div> +- </div> + + <div id="masthead" style="display: none;"> + <div class="container"> +@@ -1140,92 +1109,6 @@ + </div> + </div> + +- +- <div class="modal fade" id="updateModal" tabindex="-1" role="dialog" aria-labelledby="updateModalLabel"> +- <div class="modal-dialog" role="document"> +- <div class="modal-content"> +- <div class="modal-header"> +- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> +- <h4 class="modal-title" id="updateModalLabel">Update Check</h4> +- </div> +- <div class="modal-body"> +- Your netdata version: <b><code><span id="netdataVersion">Unknown</span></code></b><br/> +- <br/> +- <div style="padding: 10px;"></div> +- <div id="versionCheckLog">Not checked yet. Please press the Check Now button.</div> +- <div> +- <hr/> +- </div> +- <div> +- For progress reports and key netdata updates: <strong><a href="https://twitter.com/linuxnetdata" target="_blank">follow netdata on <i class="fab fa-twitter"></i> twitter</a></strong>. +- <br/> +- You can also <a href="https://www.facebook.com/linuxnetdata/" target="_blank">follow netdata on <i class="fab fa-facebook"></i> facebook</a>, +- or <a href="https://github.com/netdata/netdata" target="_blank">watch netdata on <i class="fab fa-github"></i> github</a>. +- </div> +- </div> +- <div class="modal-footer"> +- <a href="#" onclick="notifyForUpdate(true); return false;" type="button" class="btn btn-default">Check Now</a> +- <button type="button" class="btn btn-default" data-dismiss="modal">Close</button> +- </div> +- </div> +- </div> +- </div> +- +- <div class="modal fade" id="signInModal" tabindex="-1" role="dialog" aria-labelledby="signInModalLabel"> +- <div class="modal-dialog" role="document"> +- <div class="modal-content"> +- <div class="modal-header"> +- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> +- <h4 class="modal-title" id="signInModalLabel">Sign In</h4> +- </div> +- <div class="modal-body"> +- <p> +- Signing-in to netdata.cloud will synchronize the list of +- your netdata monitored nodes known at registry +- <strong><span id="sim-registry"></span></strong>. This +- may include server hostnames, urls and identification +- GUIDs. +- </p> +- <p> +- After you upgrade all your netdata servers, your private +- registry will not be needed any more. +- </p> +- <p> +- Are you sure you want to proceed? +- </p> +- </div> +- <div class="modal-footer"> +- <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button> +- <a href="#" onclick="explicitlySignIn(); return false;" type="button" class="btn btn-success">Sign In</a> +- </div> +- </div> +- </div> +- </div> +- +- <div class="modal fade" id="syncRegistryModal" tabindex="-1" role="dialog" aria-labelledby="syncRegistryModalLabel"> +- <div class="modal-dialog" role="document"> +- <div class="modal-content"> +- <div class="modal-header"> +- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> +- <h4 class="modal-title" id="syncRegistryModalLabel">Synchronize netdata.cloud with registry?</h4> +- </div> +- <div class="modal-body"> +- <p> +- You are about to synchronize your netdata.cloud account with data from the registry at <strong><span id="sync-registry-modal-registry"></span></strong>. +- This may include server hostnames, urls and identification GUIDs. +- </p> +- <p> +- Are you sure you want to proceed? +- </p> +- </div> +- <div class="modal-footer"> +- <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button> +- <a href="#" onclick="explicitlySyncAgents(); return false;" type="button" class="btn btn-success">Synchronize</a> +- </div> +- </div> +- </div> +- </div> +- + <div class="modal fade" id="deleteRegistryModal" tabindex="-1" role="dialog" aria-labelledby="deleteRegistryModalLabel"> + <div class="modal-dialog" role="document"> + <div class="modal-content"> +diff --git a/web/gui/infographic.html b/web/gui/infographic.html +deleted file mode 100644 +index 24ff8f4e..00000000 +--- a/web/gui/infographic.html ++++ /dev/null +@@ -1,171 +0,0 @@ +-<!doctype html> +-<!-- SPDX-License-Identifier: GPL-3.0-or-later --> +-<html lang=en-us> +-<head> +- <meta charset=utf-8> +- <title>NetData: Get control of your Linux Servers. Simple. Effective. Awesome.</title> +- <meta name=author content="Costa Tsaousis"> +- <meta name=description content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms."> +- +- <meta name=viewport content="width=device-width,initial-scale=1"> +- <link rel=apple-touch-icon href=apple-touch-icon.png> +- <link rel="icon" href="" /> +- +- <meta property="og:url" content="https://my-netdata.io/infographic.html" /> +- <meta property="og:type" content="website" /> +- <meta property="og:title" content="netdata infographic" /> +- <meta property="og:description" content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms." /> +- <meta property="og:image" content="https://user-images.githubusercontent.com/43294513/60951037-8ba5d180-a2f8-11e9-906e-e27356f168bc.png" /> +- <meta property="og:image:type" content="image/png" /> +- <meta property="fb:app_id" content="1200089276712916" /> +- +- <meta name="twitter:card" content="summary" /> +- <meta name="twitter:site" content="@linuxnetdata" /> +- <meta name="twitter:title" content="netdata infographic" /> +- <meta name="twitter:description" content="Unparalleled insights, in real-time, of everything happening on your Linux systems and applications, with stunning, interactive web dashboards and powerful performance and health alarms." /> +- <meta name="twitter:image" content="https://cloud.githubusercontent.com/assets/2662304/25580009/bf7016a4-2e85-11e7-9a7a-b36c57db7b91.png" /> +- +- <meta name="google-site-verification" content="3Xmk2kyCvai8p9HEnYHoQ9RBW20-b1NvPAgu07Fkkds" /> +- <meta name="msvalidate.01" content="896DCA31C9A664CE359FCF1A645DD476" /> +- +- <style>/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */ +- html { +- line-height: 1.15; +- -ms-text-size-adjust: 100%; +- -webkit-text-size-adjust: 100%; +- font: 17px/1.4 'Open Sans', sans-serif; +- text-align: center +- } +- </style> +-</head> +-<body> +-<div style="width: 100%;text-align:center;"> +- <div> +- <p style="font-size: 16pt"> +- <b>Interactive infographic of netdata features and functions</b> +- </p> +- <p> +- Hover and click on the infographic, to open the related wiki page. +- <br/> +- <small> +- The links and the docs are still a work in progress. +- The interactive infographic is a feature of <b>draw.io</b>. +- </small> +- </p> +- </div> +- <div class=site-footer role=contentinfo> +- <p> +- <div style="display: inline-block;"> +- <div style="vertical-align:top;display:inline-block; height: 34px;margin-top:3px;"><a class=twitter-share-button href=https://twitter.com/share data-count=none data-lang=en data-via=linuxnetdata data-size=small data-text="Get control of your Linux servers. Simple. Effective. Awesome." data-url=https://my-netdata.io/infographic.html >Tweet</a></div> +- <div style="vertical-align:top;display:inline-block; height: 34px;margin-top:3px;"><a class=twitter-follow-button href=https://twitter.com/linuxnetdata data-show-count=false data-lang=en data-size=small>Follow @linuxnetdata</a></div> +- </div> +- <div style="display: inline-block;"> +- <div class="fb-like" data-href="https://my-netdata.io/" data-layout="button" data-action="like" data-show-faces="false" data-share="false" style="vertical-align:top;display:inline-block; height: 34px;"></div> +- <div class="fb-share-button" data-href="https://my-netdata.io/" data-layout="button" data-size="small" data-mobile-iframe="true"><a class="fb-xfbml-parse-ignore" target="_blank" href="https://www.facebook.com/sharer/sharer.php?u=https%3A%2F%2Fmy-netdata.io%2Finfographic.html&src=sdkpreparse" style="vertical-align:top;display:inline-block; height: 34px;">Share</a></div> +- </div> +- </div> +- <div> +- <p style="font-size: 14pt"> +- <b>New to netdata?</b> <a href="//my-netdata.io" target="_blank">Have a look at a netdata demo</a>. You will love it! +- </p> +- <p> +- <embed style="padding-top: 10px; padding-botton: 25px;" src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_entries&dimensions=persons&label=user%20base&units=null&value_color=blue&precision=0&v42" type="image/svg+xml" height="20" /> +- <embed style="padding-top: 10px; padding-botton: 25px;" src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_entries&dimensions=machines&label=servers%20monitored&units=null&value_color=orange&precision=0&v42" type="image/svg+xml" height="20" /> +- <embed style="padding-top: 10px; padding-botton: 25px;" src="//registry.my-netdata.io/api/v1/badge.svg?chart=netdata.registry_sessions&label=sessions%20served&units=null&value_color=yellowgreen&precision=0&v42" type="image/svg+xml" height="20" /> +- </p> +- <hr/> +- </div> +- <div style="width:90%;display:inline-block;max-width:1300px;text-align:left;"> +- <div id="drawing" class="mxgraph" style="max-width:100%;border:1px solid transparent;"></div> +- </div> +-</div> +-</body> +- +-<script> +- var opts = { +- "highlight":"#0000ff", +- "target":"blank", +- "lightbox":false, +- "nav":false, +- "resize":true, +- "toolbar":"", +- "auto-fit":true, +- "check-visible-state":false, +- "edit":"https://raw.githubusercontent.com/netdata/netdata/master/diagrams/netdata-overview.xml", +- "url":"https://raw.githubusercontent.com/netdata/netdata/master/diagrams/netdata-overview.xml" +- }; +- document.getElementById("drawing").dataset.mxgraph = JSON.stringify(opts); +-</script> +- +-<script> +- if(window.location.hostname != 'my-netdata.io' || window.location.protocol != 'https:') { +- var canonical = document.createElement('link'); +- canonical.rel = 'canonical'; +- canonical.href = 'https://my-netdata.io/infographic.html'; +- document.head.appendChild(canonical); +- } +-</script> +- +-<script>!function (t, e) { +- "use strict"; +- function a(t, n) { +- return t.hasAttribute(n) === !0 ? t : t.parentNode !== r.body ? a(t.parentNode, n) : e +- } +- +- function n(n) { +- var o, i, r, c, g, u = a(n.target, "data-ga-action"), l = !1; +- u !== e && (o = u.getAttribute("data-ga-action") || e, i = u.getAttribute("data-ga-category") || e, r = u.getAttribute("data-ga-label") || e, c = u.getAttribute("href"), g = parseInt(u.getAttribute("data-ga-value"), 10) || e, ga !== e && i !== e && o !== e && (n.preventDefault(), "Download" !== i && n.ctrlKey !== !0 && n.metaKey !== !0 && 2 !== n.which || (l = !0, t.open(c)), function (a) { +- var n; +- ga("send", "event", i, o, r, g, { +- hitCallback: function () { +- l === !1 && (n !== e && clearTimeout(n), t.location = a) +- } +- }), n = setTimeout(function () { +- l === !1 && (t.location.href = a) +- }, 1e3) +- }(c))) +- } +- +- function o() { +- !function (t, e, a, n, o, i) { +- t.GoogleAnalyticsObject = n, t[n] || (t[n] = function () { +- (t[n].q = t[n].q || []).push(arguments) +- }), t[n].l = +new Date, o = e.createElement(a), i = e.getElementsByTagName(a)[0], o.src = "//www.google-analytics.com/analytics.js", i.parentNode.insertBefore(o, i) +- }(t, r, "script", "ga"), ga("create", "UA-64295674-3", "auto"), ga("send", "pageview"), t.document.addEventListener("click", n) +- } +- +- function i() { +- !function (t, e, a) { +- var n, o = t.getElementsByTagName(e)[0]; +- t.getElementById(a) || (n = t.createElement(e), n.id = a, n.src = "//platform.twitter.com/widgets.js", o.parentNode.insertBefore(n, o)) +- }(r, "script", "twitter-wjs") +- } +- +- var r = t.document; +- o(), t.onload = i +-}(window)</script> +- +-<!-- facebook sdk --> +-<div id="fb-root"></div> +-<script> +- window.fbAsyncInit = function() { +- FB.init({ +- appId : '1200089276712916', +- xfbml : true, +- version : 'v2.8' +- }); +- }; +- +- (function(d, s, id){ +- var js, fjs = d.getElementsByTagName(s)[0]; +- if (d.getElementById(id)) {return;} +- js = d.createElement(s); js.id = id; +- js.src = "//connect.facebook.net/en_US/sdk.js"; +- fjs.parentNode.insertBefore(js, fjs); +- }(document, 'script', 'facebook-jssdk')); +-</script> +- +-<script type="text/javascript" src="https://www.draw.io/embed2.js?s=arrows2;mscae/cloud;azure;office/users;office/servers&fetch=https%3A%2F%2Fraw.githubusercontent.com%2Fnetdata%2Fnetdata%2Fmaster%2Fdiagrams%2Fnetdata-overview.xml"></script> +- +-</html> +- +diff --git a/web/gui/main.js b/web/gui/main.js +index 5bf11e5f..d30192b4 100644 +--- a/web/gui/main.js ++++ b/web/gui/main.js +@@ -17,9 +17,6 @@ var netdataServer = undefined; + var netdataServerStatic = undefined; + var netdataCheckXSS = undefined; + +-// control the welcome modal and analytics +-var this_is_demo = null; +- + function escapeUserInputHTML(s) { + return s.toString() + .replace(/&/g, '&') +@@ -206,7 +203,6 @@ var urlOptions = { + + netdataShowAlarms = false; + netdataRegistry = false; +- this_is_demo = false; + break; + + case 'live': +@@ -678,32 +674,6 @@ function renderMachines(machinesArray) { + </div>` + ) + } +- +- html += `<hr />`; +- html += `<div class="info-item">Demo netdata nodes</div>`; +- +- const demoServers = [ +- { url: "//london.netdata.rocks/default.html", title: "UK - London (DigitalOcean.com)" }, +- { url: "//newyork.netdata.rocks/default.html", title: "US - New York (DigitalOcean.com)" }, +- { url: "//sanfrancisco.netdata.rocks/default.html", title: "US - San Francisco (DigitalOcean.com)" }, +- { url: "//atlanta.netdata.rocks/default.html", title: "US - Atlanta (CDN77.com)" }, +- { url: "//frankfurt.netdata.rocks/default.html", title: "Germany - Frankfurt (DigitalOcean.com)" }, +- { url: "//toronto.netdata.rocks/default.html", title: "Canada - Toronto (DigitalOcean.com)" }, +- { url: "//singapore.netdata.rocks/default.html", title: "Japan - Singapore (DigitalOcean.com)" }, +- { url: "//bangalore.netdata.rocks/default.html", title: "India - Bangalore (DigitalOcean.com)" }, +- +- ] +- +- for (var server of demoServers) { +- html += ( +- `<div class="agent-item"> +- <i class="fas fa-chart-bar" style="color: #fff"></i> +- <a href="${server.url}">${server.title}</a> +- <div></div> +- </div> +- ` +- ); +- } + } + + return html; +@@ -723,25 +693,9 @@ function clearMyNetdataMenu() { + } + + function errorMyNetdataMenu() { +- setMyNetdataMenu(`<div class="agent-item" style="padding: 0 8px"> +- <i class="fas fa-exclamation-triangle" style="color: red"></i> +- Cannot load known Netdata agents from Netdata Cloud! Please make sure you have the latest version of Netdata. +- </div>`); + } + + function restrictMyNetdataMenu() { +- setMyNetdataMenu(`<div class="info-item" style="white-space: nowrap"> +- <span>Please <a href="#" onclick="signInDidClick(event); return false">sign in to netdata.cloud</a> to view your nodes!</span> +- <div></div> +- </div>`); +-} +- +-function openAuthenticatedUrl(url) { +- if (isSignedIn()) { +- window.open(url); +- } else { +- window.open(`${NETDATA.registry.cloudBaseURL}/account/sign-in-agent?id=${NETDATA.registry.machine_guid}&name=${encodeURIComponent(NETDATA.registry.hostname)}&origin=${encodeURIComponent(window.location.origin + "/")}&redirect_uri=${encodeURIComponent(window.location.origin + "/" + url)}`); +- } + } + + function renderMyNetdataMenu(machinesArray) { +@@ -750,42 +704,10 @@ function renderMyNetdataMenu(machinesArray) { + + if (machinesArray == registryAgents) { + console.log("Rendering my-netdata menu from registry"); +- } else { +- console.log("Rendering my-netdata menu from netdata.cloud", machinesArray); + } + + let html = ''; + +- if (!isSignedIn()) { +- if (!NETDATA.registry.isRegistryEnabled()) { +- html += ( +- `<div class="info-item" style="white-space: nowrap"> +- <span>Please <a href="#" onclick="signInDidClick(event); return false">sign in to netdata.cloud</a> to view your nodes!</span> +- <div></div> +- </div> +- <hr />` +- ); +- } +- } +- +- if (isSignedIn()) { +- html += ( +- `<div class="filter-control"> +- <input +- id="my-netdata-menu-filter-input" +- type="text" +- placeholder="filter nodes..." +- autofocus +- autocomplete="off" +- value="${myNetdataMenuFilterValue}" +- onkeydown="myNetdataFilterDidChange(event)" +- /> +- <span class="filter-control__clear" onclick="myNetdataFilterClearDidClick(event)"><i class="fas fa-times"></i><span> +- </div> +- <hr />` +- ); +- } +- + // options.hosts = [ + // { + // hostname: "streamed1", +@@ -799,73 +721,15 @@ function renderMyNetdataMenu(machinesArray) { + html += `<div id="my-netdata-menu-streamed">${renderStreamedHosts(options)}</div><hr />`; + } + +- if (isSignedIn() || NETDATA.registry.isRegistryEnabled()) { ++ if (NETDATA.registry.isRegistryEnabled()) { + html += `<div id="my-netdata-menu-machines">${renderMachines(machinesArray)}</div><hr />`; + } + +- if (!isSignedIn()) { +- html += ( +- `<div class="agent-item"> +- <i class="fas fa-cog""></i> +- <a href="#" onclick="switchRegistryModalHandler(); return false;">Switch Identity</a> +- <div></div> +- </div> +- <div class="agent-item"> +- <i class="fas fa-question-circle""></i> +- <a href="https://github.com/netdata/netdata/tree/master/registry#netdata-registry" target="_blank">What is this?</a> +- <div></div> +- </div>` +- ) +- } else { +- html += ( +- `<div class="agent-item"> +- <i class="fas fa-tv"></i> +- <a onclick="openAuthenticatedUrl('console.html');" target="_blank">Nodes<sup class="beta"> beta</sup></a> +- <div></div> +- </div> +- <div class="agent-item"> +- <i class="fas fa-sync"></i> +- <a href="#" onclick="showSyncModal(); return false">Synchronize with netdata.cloud</a> +- <div></div> +- </div> +- <div class="agent-item"> +- <i class="fas fa-question-circle""></i> +- <a href="https://netdata.cloud/about" target="_blank">What is this?</a> +- <div></div> +- </div>` +- ) +- } +- + el.innerHTML = html; + + gotoServerInit(); + } + +-function isdemo() { +- if (this_is_demo !== null) { +- return this_is_demo; +- } +- this_is_demo = false; +- +- try { +- if (typeof document.location.hostname === 'string') { +- if (document.location.hostname.endsWith('.my-netdata.io') || +- document.location.hostname.endsWith('.mynetdata.io') || +- document.location.hostname.endsWith('.netdata.rocks') || +- document.location.hostname.endsWith('.netdata.ai') || +- document.location.hostname.endsWith('.netdata.live') || +- document.location.hostname.endsWith('.firehol.org') || +- document.location.hostname.endsWith('.netdata.online') || +- document.location.hostname.endsWith('.netdata.cloud')) { +- this_is_demo = true; +- } +- } +- } +- catch (error) { +- } +- return this_is_demo; +-} +- + function netdataURL(url, forReload) { + if (typeof url === 'undefined') + // url = document.location.toString(); +@@ -973,28 +837,26 @@ function gotoServerModalHandler(guid) { + gotoServerValidateUrl(count++, guid, url); + } + +- if (!isSignedIn()) { +- // When the registry is enabled, if the user's known URLs are not working +- // we consult the registry to get additional URLs. +- setTimeout(function () { +- if (gotoServerStop === false) { +- document.getElementById('gotoServerResponse').innerHTML = '<b>Added all the known URLs for this machine.</b>'; +- NETDATA.registry.search(guid, function (data) { +- // console.log(data); +- len = data.urls.length; +- while (len--) { +- var url = data.urls[len][1]; +- // console.log(url); +- if (typeof checked[url] === 'undefined') { +- gotoServerValidateRemaining++; +- checked[url] = true; +- gotoServerValidateUrl(count++, guid, url); +- } ++ // When the registry is enabled, if the user's known URLs are not working ++ // we consult the registry to get additional URLs. ++ setTimeout(function () { ++ if (gotoServerStop === false) { ++ document.getElementById('gotoServerResponse').innerHTML = '<b>Added all the known URLs for this machine.</b>'; ++ NETDATA.registry.search(guid, function (data) { ++ // console.log(data); ++ len = data.urls.length; ++ while (len--) { ++ var url = data.urls[len][1]; ++ // console.log(url); ++ if (typeof checked[url] === 'undefined') { ++ gotoServerValidateRemaining++; ++ checked[url] = true; ++ gotoServerValidateUrl(count++, guid, url); + } +- }); +- } +- }, 2000); +- } ++ } ++ }); ++ } ++ }, 2000); + + return false; + } +@@ -1057,34 +919,15 @@ function notifyForDeleteRegistry() { + const responseEl = document.getElementById('deleteRegistryResponse'); + + if (deleteRegistryUrl) { +- if (isSignedIn()) { +- deleteCloudAgentURL(deleteRegistryGuid, deleteRegistryUrl) +- .then((count) => { +- if (!count) { +- responseEl.innerHTML = "<b>Sorry, this command was rejected by netdata.cloud!</b>"; +- return; +- } +- NETDATA.registry.delete(deleteRegistryUrl, function (result) { +- if (result === null) { +- console.log("Received error from registry", result); +- } +- +- deleteRegistryUrl = null; +- $('#deleteRegistryModal').modal('hide'); +- NETDATA.registry.init(); +- }); +- }); +- } else { +- NETDATA.registry.delete(deleteRegistryUrl, function (result) { +- if (result !== null) { +- deleteRegistryUrl = null; +- $('#deleteRegistryModal').modal('hide'); +- NETDATA.registry.init(); +- } else { +- responseEl.innerHTML = "<b>Sorry, this command was rejected by the registry server!</b>"; +- } +- }); +- } ++ NETDATA.registry.delete(deleteRegistryUrl, function (result) { ++ if (result !== null) { ++ deleteRegistryUrl = null; ++ $('#deleteRegistryModal').modal('hide'); ++ NETDATA.registry.init(); ++ } else { ++ responseEl.innerHTML = "<b>Sorry, this command was rejected by the registry server!</b>"; ++ } ++ }); + } + } + +@@ -2367,11 +2210,7 @@ function alarmsUpdateModal() { + void ($element); + let main_url; + let common_url = "&host=" + encodeURIComponent(row['hostname']) + "&chart=" + encodeURIComponent(row['chart']) + "&family=" + encodeURIComponent(row['family']) + "&alarm=" + encodeURIComponent(row['name']) + "&alarm_unique_id=" + row['unique_id'] + "&alarm_id=" + row['alarm_id'] + "&alarm_event_id=" + row['alarm_event_id'] + "&alarm_when=" + row['when']; +- if (NETDATA.registry.isUsingGlobalRegistry() && NETDATA.registry.machine_guid != null) { +- main_url = "https://netdata.cloud/alarms/redirect?agentID=" + NETDATA.registry.machine_guid + common_url; +- } else { +- main_url = NETDATA.registry.server + "/goto-host-from-alarm.html?" + common_url ; +- } ++ main_url = NETDATA.registry.server + "/goto-host-from-alarm.html?" + common_url ; + window.open(main_url,"_blank"); + }, + rowStyle: function (row, index) { +@@ -2803,7 +2642,6 @@ function initializeDynamicDashboardWithData(data) { + // update the dashboard hostname + document.getElementById('hostname').innerHTML = '<span id="hostnametext">' + options.hostname + ((netdataSnapshotData !== null) ? ' (snap)' : '').toString() + '</span> <strong class="caret">'; + document.getElementById('hostname').href = NETDATA.serverDefault; +- document.getElementById('netdataVersion').innerHTML = options.version; + + if (netdataSnapshotData !== null) { + $('#alarmsButton').hide(); +@@ -2836,7 +2674,7 @@ function initializeDynamicDashboardWithData(data) { + renderChartsAndMenu(data); + + // Ensure MyNetdata menu is rendered with latest host info #5370 +- renderMyNetdataMenu(isSignedIn() ? cloudAgents : registryAgents); ++ renderMyNetdataMenu(registryAgents); + } + } + +@@ -4136,18 +3974,10 @@ function runOnceOnDashboardWithjQuery() { + // ------------------------------------------------------------------------ + // sidebar / affix + +- if (shouldShowSignInBanner()) { +- const el = document.getElementById("sign-in-banner"); +- if (el) { +- el.style.display = "initial"; +- el.classList.add(`theme-${netdataTheme}`); +- } +- } +- + $('#sidebar') + .affix({ + offset: { +- top: (isdemo()) ? 150 : 0, ++ top: 0, + bottom: 0 + } + }) +@@ -4457,32 +4287,6 @@ function finalizePage() { + $(".shorten").shorten(); + enableTooltipsAndPopovers(); + +- if (isdemo()) { +- // do not to give errors on netdata demo servers for 60 seconds +- NETDATA.options.current.retries_on_data_failures = 60; +- +- // google analytics when this is used for the home page of the demo sites +- // this does not run on user's installations +- setTimeout(function () { +- (function (i, s, o, g, r, a, m) { +- i['GoogleAnalyticsObject'] = r; +- i[r] = i[r] || function () { +- (i[r].q = i[r].q || []).push(arguments) +- }, i[r].l = 1 * new Date(); +- a = s.createElement(o), +- m = s.getElementsByTagName(o)[0]; +- a.async = 1; +- a.src = g; +- m.parentNode.insertBefore(a, m) +- })(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga'); +- +- ga('create', 'UA-64295674-3', 'auto'); +- ga('send', 'pageview', '/demosite/' + window.location.host); +- }, 2000); +- } else { +- notifyForUpdate(); +- } +- + if (urlOptions.show_alarms === true) { + setTimeout(function () { + $('#alarmsModal').modal('show'); +@@ -4547,12 +4351,9 @@ var netdataPrepCallback = function () { + } + }); + +- if (isdemo()) { +- document.getElementById('masthead').style.display = 'block'; +- } else { +- if (urlOptions.update_always === true) { +- NETDATA.setOption('stop_updates_when_focus_is_lost', !urlOptions.update_always); +- } ++ ++ if (urlOptions.update_always === true) { ++ NETDATA.setOption('stop_updates_when_focus_is_lost', !urlOptions.update_always); + } + }; + +@@ -4614,542 +4415,4 @@ var selected_server_timezone = function (timezone, status) { + // our entry point + // var netdataStarted = performance.now(); + +-var netdataCallback = initializeDynamicDashboard; +- +-// ================================================================================================= +-// netdata.cloud +- +-let registryAgents = []; +- +-let cloudAgents = []; +- +-let myNetdataMenuFilterValue = ""; +- +-let cloudAccountID = null; +- +-let cloudAccountName = null; +- +-let cloudToken = null; +- +-/// Enforces a maximum string length while retaining the prefix and the postfix of +-/// the string. +-function truncateString(str, maxLength) { +- if (str.length <= maxLength) { +- return str; +- } +- +- const spanLength = Math.floor((maxLength - 3) / 2); +- return `${str.substring(0, spanLength)}...${str.substring(str.length - spanLength)}`; +-} +- +-// ------------------------------------------------------------------------------------------------- +-// netdata.cloud API Client +-// ------------------------------------------------------------------------------------------------- +- +-function isValidAgent(a) { +- return a.urls != null && a.urls.length > 0; +-} +- +-// https://github.com/netdata/hub/issues/146 +-function getCloudAccountAgents() { +- if (!isSignedIn()) { +- return []; +- } +- +- return fetch( +- `${NETDATA.registry.cloudBaseURL}/api/v1/accounts/${cloudAccountID}/agents`, +- { +- method: "GET", +- mode: "cors", +- headers: { +- "Authorization": `Bearer ${cloudToken}` +- } +- } +- ).then((response) => { +- if (!response.ok) { +- throw Error("Cannot fetch known accounts"); +- } +- return response.json(); +- }).then((payload) => { +- const agents = payload.result ? payload.result.agents : null; +- +- if (!agents) { +- return []; +- } +- +- return agents.filter((a) => isValidAgent(a)).map((a) => { +- return { +- "guid": a.id, +- "name": a.name, +- "url": a.urls[0], +- "alternate_urls": a.urls +- } +- }) +- }).catch(function (error) { +- console.log(error); +- return null; +- }); +-} +- +-/** Updates the lastAccessTime and accessCount properties of the agent for the account. */ +-function touchAgent() { +- if (!isSignedIn()) { +- return []; +- } +- +- const touchUrl = `${NETDATA.registry.cloudBaseURL}/api/v1/agents/${NETDATA.registry.machine_guid}/touch?account_id=${cloudAccountID}`; +- return fetch( +- touchUrl, +- { +- method: "post", +- body: "", +- mode: "cors", +- headers: { +- "Authorization": `Bearer ${cloudToken}` +- } +- } +- ).then((response) => { +- if (!response.ok) { +- throw Error("Cannot touch agent" + JSON.stringify(response)); +- } +- return response.json(); +- }).then((payload) => { +- +- }).catch(function (error) { +- console.log(error); +- return null; +- }); +-} +- +-// https://github.com/netdata/hub/issues/128 +-function postCloudAccountAgents(agentsToSync) { +- if (!isSignedIn()) { +- return []; +- } +- +- const maskedURL = NETDATA.registry.MASKED_DATA; +- +- const agents = agentsToSync.map((a) => { +- const urls = a.alternate_urls.filter((url) => url != maskedURL); +- +- return { +- "id": a.guid, +- "name": a.name, +- "urls": urls +- } +- }).filter((a) => isValidAgent(a)) +- +- const payload = { +- "accountID": cloudAccountID, +- "agents": agents, +- "merge": false, +- }; +- +- return fetch( +- `${NETDATA.registry.cloudBaseURL}/api/v1/accounts/${cloudAccountID}/agents`, +- { +- method: "POST", +- mode: "cors", +- headers: { +- "Content-Type": "application/json; charset=utf-8", +- "Authorization": `Bearer ${cloudToken}` +- }, +- body: JSON.stringify(payload) +- } +- ).then((response) => { +- return response.json(); +- }).then((payload) => { +- const agents = payload.result ? payload.result.agents : null; +- +- if (!agents) { +- return []; +- } +- +- return agents.filter((a) => isValidAgent(a)).map((a) => { +- return { +- "guid": a.id, +- "name": a.name, +- "url": a.urls[0], +- "alternate_urls": a.urls +- } +- }) +- }); +-} +- +-function deleteCloudAgentURL(agentID, url) { +- if (!isSignedIn()) { +- return []; +- } +- +- return fetch( +- `${NETDATA.registry.cloudBaseURL}/api/v1/accounts/${cloudAccountID}/agents/${agentID}/url?value=${encodeURIComponent(url)}`, +- { +- method: "DELETE", +- mode: "cors", +- headers: { +- "Content-Type": "application/json; charset=utf-8", +- "Authorization": `Bearer ${cloudToken}` +- }, +- } +- ).then((response) => { +- return response.json(); +- }).then((payload) => { +- const count = payload.result ? payload.result.count : 0; +- return count; +- }); +-} +- +-// ------------------------------------------------------------------------------------------------- +- +-function signInDidClick(e) { +- e.preventDefault(); +- e.stopPropagation(); +- +- if (!NETDATA.registry.isUsingGlobalRegistry()) { +- // If user is using a private registry, request his consent for +- // synchronizing with cloud. +- showSignInModal(); +- return; +- } +- +- signIn(); +-} +- +-function shouldShowSignInBanner() { +- return false; +-} +- +-function closeSignInBanner() { +- localStorage.setItem("signInBannerClosed", "true"); +- const el = document.getElementById("sign-in-banner"); +- if (el) { +- el.style.display = "none"; +- } +-} +- +-function closeSignInBannerDidClick(e) { +- closeSignInBanner(); +-} +- +-function signOutDidClick(e) { +- e.preventDefault(); +- e.stopPropagation(); +- signOut(); +-} +- +-// ------------------------------------------------------------------------------------------------- +- +-function updateMyNetdataAfterFilterChange() { +- const machinesEl = document.getElementById("my-netdata-menu-machines") +- machinesEl.innerHTML = renderMachines(cloudAgents); +- +- if (options.hosts.length > 1) { +- const streamedEl = document.getElementById("my-netdata-menu-streamed") +- streamedEl.innerHTML = renderStreamedHosts(options); +- } +-} +- +-function myNetdataMenuDidShow() { +- const filterEl = document.getElementById("my-netdata-menu-filter-input"); +- if (filterEl) { +- filterEl.focus(); +- } +-} +- +-function myNetdataFilterDidChange(e) { +- const inputEl = e.target; +- setTimeout(() => { +- myNetdataMenuFilterValue = inputEl.value; +- updateMyNetdataAfterFilterChange(); +- }, 1); +-} +- +-function myNetdataFilterClearDidClick(e) { +- e.preventDefault(); +- e.stopPropagation(); +- +- const inputEl = document.getElementById("my-netdata-menu-filter-input"); +- inputEl.value = ""; +- myNetdataMenuFilterValue = ""; +- +- updateMyNetdataAfterFilterChange(); +- +- inputEl.focus(); +-} +- +-// ------------------------------------------------------------------------------------------------- +- +-function clearCloudVariables() { +- cloudAccountID = null; +- cloudAccountName = null; +- cloudToken = null; +-} +- +-function clearCloudLocalStorageItems() { +- localStorage.removeItem("cloud.baseURL"); +- localStorage.removeItem("cloud.agentID"); +- localStorage.removeItem("cloud.sync"); +-} +- +-function signIn() { +- const url = `${NETDATA.registry.cloudBaseURL}/account/sign-in-agent?id=${NETDATA.registry.machine_guid}&name=${encodeURIComponent(NETDATA.registry.hostname)}&origin=${encodeURIComponent(window.location.origin + "/")}`; +- window.open(url); +-} +- +-function signOut() { +- cloudSSOSignOut(); +-} +- +-function handleMessage(e) { +- switch (e.data.type) { +- case "sign-in": +- handleSignInMessage(e); +- break; +- +- case "sign-out": +- handleSignOutMessage(e); +- break; +- +- default: +- return; +- } +-} +- +-function handleSignInMessage(e) { +- closeSignInBanner(); +- localStorage.setItem("cloud.baseURL", NETDATA.registry.cloudBaseURL); +- +- cloudAccountID = e.data.accountID; +- cloudAccountName = e.data.accountName; +- cloudToken = e.data.token; +- +- netdataRegistryCallback(registryAgents); +- if (e.data.redirectURI && !window.location.href.includes(e.data.redirectURI)) { +- // lgtm false-positive - redirectURI does not come from user input, but from iframe callback +- window.location.replace(e.data.redirectURI); // lgtm[js/client-side-unvalidated-url-redirection] +- } +-} +- +-function handleSignOutMessage(e) { +- clearCloudVariables(); +- renderMyNetdataMenu(registryAgents); +-} +- +-function isSignedIn() { +- return cloudToken != null && cloudAccountID != null; +-} +- +-function sortedArraysEqual(a, b) { +- if (a.length != b.length) return false; +- +- for (var i = 0; i < a.length; ++i) { +- if (a[i] !== b[i]) return false; +- } +- +- return true; +-} +- +-// If merging is needed returns the merged agents set, otherwise returns null. +-function mergeAgents(cloud, local) { +- let dirty = false; +- +- const union = new Map(); +- +- for (const cagent of cloud) { +- union.set(cagent.guid, cagent); +- } +- +- for (const lagent of local) { +- const cagent = union.get(lagent.guid); +- if (cagent) { +- for (const u of lagent.alternate_urls) { +- if (u === NETDATA.registry.MASKED_DATA) { // TODO: temp until registry is updated. +- continue; +- } +- +- if (!cagent.alternate_urls.includes(u)) { +- dirty = true; +- cagent.alternate_urls.push(u); +- } +- } +- } else { +- dirty = true; +- union.set(lagent.guid, lagent); +- } +- } +- +- if (dirty) { +- return Array.from(union.values()); +- } +- +- return null; +-} +- +-function showSignInModal() { +- document.getElementById("sim-registry").innerHTML = NETDATA.registry.server; +- $("#signInModal").modal("show"); +-} +- +-function explicitlySignIn() { +- $("#signInModal").modal("hide"); +- signIn(); +-} +- +-function showSyncModal() { +- document.getElementById("sync-registry-modal-registry").innerHTML = NETDATA.registry.server; +- $("#syncRegistryModal").modal("show"); +-} +- +-function explicitlySyncAgents() { +- $("#syncRegistryModal").modal("hide"); +- +- const json = localStorage.getItem("cloud.sync"); +- const sync = json ? JSON.parse(json) : {}; +- delete sync[cloudAccountID]; +- localStorage.setItem("cloud.sync", JSON.stringify(sync)); +- +- NETDATA.registry.init(); +-} +- +-function syncAgents(callback) { +- const json = localStorage.getItem("cloud.sync"); +- const sync = json ? JSON.parse(json) : {}; +- +- const currentAgent = { +- guid: NETDATA.registry.machine_guid, +- name: NETDATA.registry.hostname, +- url: NETDATA.serverDefault, +- alternate_urls: [NETDATA.serverDefault], +- } +- +- const localAgents = sync[cloudAccountID] +- ? [currentAgent] +- : registryAgents.concat([currentAgent]); +- +- console.log("Checking if sync is needed.", localAgents); +- +- const agentsToSync = mergeAgents(cloudAgents, localAgents); +- +- if ((!sync[cloudAccountID]) || agentsToSync) { +- sync[cloudAccountID] = new Date().getTime(); +- localStorage.setItem("cloud.sync", JSON.stringify(sync)); +- } +- +- if (agentsToSync) { +- console.log("Synchronizing with netdata.cloud."); +- +- postCloudAccountAgents(agentsToSync).then((agents) => { +- // TODO: clear syncTime on error! +- cloudAgents = agents; +- callback(cloudAgents); +- }); +- +- return +- } +- +- callback(cloudAgents); +-} +- +-let isCloudSSOInitialized = false; +- +-function cloudSSOInit() { +- const iframeEl = document.getElementById("ssoifrm"); +- const url = `${NETDATA.registry.cloudBaseURL}/account/sso-agent?id=${NETDATA.registry.machine_guid}`; +- iframeEl.src = url; +- isCloudSSOInitialized = true; +-} +- +-function cloudSSOSignOut() { +- const iframe = document.getElementById("ssoifrm"); +- const url = `${NETDATA.registry.cloudBaseURL}/account/sign-out-agent`; +- iframe.src = url; +-} +- +-function initCloud() { +- if (!NETDATA.registry.isCloudEnabled) { +- clearCloudVariables(); +- clearCloudLocalStorageItems(); +- return; +- } +- +- if (NETDATA.registry.cloudBaseURL != localStorage.getItem("cloud.baseURL")) { +- clearCloudVariables(); +- clearCloudLocalStorageItems(); +- if (NETDATA.registry.cloudBaseURL) { +- localStorage.setItem("cloud.baseURL", NETDATA.registry.cloudBaseURL); +- } +- } +- +- if (!isCloudSSOInitialized) { +- cloudSSOInit(); +- } +- +- touchAgent(); +-} +- +-// This callback is called after NETDATA.registry is initialized. +-function netdataRegistryCallback(machinesArray) { +- localStorage.setItem("cloud.agentID", NETDATA.registry.machine_guid); +- +- initCloud(); +- +- registryAgents = machinesArray; +- +- if (isSignedIn()) { +- // We call getCloudAccountAgents() here because it requires that +- // NETDATA.registry is initialized. +- clearMyNetdataMenu(); +- getCloudAccountAgents().then((agents) => { +- if (!agents) { +- errorMyNetdataMenu(); +- return; +- } +- cloudAgents = agents; +- syncAgents((agents) => { +- const agentsMap = {} +- for (const agent of agents) { +- agentsMap[agent.guid] = agent; +- } +- +- NETDATA.registry.machines = agentsMap; +- NETDATA.registry.machines_array = agents; +- +- renderMyNetdataMenu(agents); +- }); +- }); +- } else { +- renderMyNetdataMenu(machinesArray) +- } +-}; +- +-// If we know the cloudBaseURL and agentID from local storage render (eagerly) +-// the account ui before receiving the definitive response from the web server. +-// This improves the perceived performance. +-function tryFastInitCloud() { +- const baseURL = localStorage.getItem("cloud.baseURL"); +- const agentID = localStorage.getItem("cloud.agentID"); +- +- if (baseURL && agentID) { +- NETDATA.registry.cloudBaseURL = baseURL; +- NETDATA.registry.machine_guid = agentID; +- NETDATA.registry.isCloudEnabled = true; +- +- initCloud(); +- } +-} +- +-function initializeApp() { +- window.addEventListener("message", handleMessage, false); +- +- // tryFastInitCloud(); +-} +- +-if (document.readyState === "complete") { +- initializeApp(); +-} else { +- document.addEventListener("readystatechange", () => { +- if (document.readyState === "complete") { +- initializeApp(); +- } +- }); +-} ++var netdataCallback = initializeDynamicDashboard; +\ No newline at end of file +diff --git a/web/gui/old/index.html b/web/gui/old/index.html +index 94ec12b7..cffa335e 100644 +--- a/web/gui/old/index.html ++++ b/web/gui/old/index.html +@@ -108,17 +108,6 @@ + <div class="navbar-highlight"> + <div id="navbar-highlight-content" class="navbar-highlight-content"></div> + </div> +- +- <div id="sign-in-banner" style="display: none"> +- <div class="container"> +- Like what you see? +- <strong><a href="#" class="__link" onclick="signInDidClick(event); return false">Sign in</a> +- to experience the full-range of netdata capabilities!</strong> +- <div class="__close" onclick="closeSignInBannerDidClick(event)"> +- Close <i class="fas fa-times"></i> +- </div> +- </div> +- </div> + + <div id="masthead" style="display: none;"> + <div class="container"> +@@ -1139,92 +1128,6 @@ + </div> + </div> + +- +- <div class="modal fade" id="updateModal" tabindex="-1" role="dialog" aria-labelledby="updateModalLabel"> +- <div class="modal-dialog" role="document"> +- <div class="modal-content"> +- <div class="modal-header"> +- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> +- <h4 class="modal-title" id="updateModalLabel">Update Check</h4> +- </div> +- <div class="modal-body"> +- Your netdata version: <b><code><span id="netdataVersion">Unknown</span></code></b><br/> +- <br/> +- <div style="padding: 10px;"></div> +- <div id="versionCheckLog">Not checked yet. Please press the Check Now button.</div> +- <div> +- <hr/> +- </div> +- <div> +- For progress reports and key netdata updates: <strong><a href="https://twitter.com/linuxnetdata" target="_blank">follow netdata on <i class="fab fa-twitter"></i> twitter</a></strong>. +- <br/> +- You can also <a href="https://www.facebook.com/linuxnetdata/" target="_blank">follow netdata on <i class="fab fa-facebook"></i> facebook</a>, +- or <a href="https://github.com/netdata/netdata" target="_blank">watch netdata on <i class="fab fa-github"></i> github</a>. +- </div> +- </div> +- <div class="modal-footer"> +- <a href="#" onclick="notifyForUpdate(true); return false;" type="button" class="btn btn-default">Check Now</a> +- <button type="button" class="btn btn-default" data-dismiss="modal">Close</button> +- </div> +- </div> +- </div> +- </div> +- +- <div class="modal fade" id="signInModal" tabindex="-1" role="dialog" aria-labelledby="signInModalLabel"> +- <div class="modal-dialog" role="document"> +- <div class="modal-content"> +- <div class="modal-header"> +- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> +- <h4 class="modal-title" id="signInModalLabel">Sign In</h4> +- </div> +- <div class="modal-body"> +- <p> +- Signing-in to netdata.cloud will synchronize the list of +- your netdata monitored nodes known at registry +- <strong><span id="sim-registry"></span></strong>. This +- may include server hostnames, urls and identification +- GUIDs. +- </p> +- <p> +- After you upgrade all your netdata servers, your private +- registry will not be needed any more. +- </p> +- <p> +- Are you sure you want to proceed? +- </p> +- </div> +- <div class="modal-footer"> +- <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button> +- <a href="#" onclick="explicitlySignIn(); return false;" type="button" class="btn btn-success">Sign In</a> +- </div> +- </div> +- </div> +- </div> +- +- <div class="modal fade" id="syncRegistryModal" tabindex="-1" role="dialog" aria-labelledby="syncRegistryModalLabel"> +- <div class="modal-dialog" role="document"> +- <div class="modal-content"> +- <div class="modal-header"> +- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button> +- <h4 class="modal-title" id="syncRegistryModalLabel">Synchronize netdata.cloud with registry?</h4> +- </div> +- <div class="modal-body"> +- <p> +- You are about to synchronize your netdata.cloud account with data from the registry at <strong><span id="sync-registry-modal-registry"></span></strong>. +- This may include server hostnames, urls and identification GUIDs. +- </p> +- <p> +- Are you sure you want to proceed? +- </p> +- </div> +- <div class="modal-footer"> +- <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button> +- <a href="#" onclick="explicitlySyncAgents(); return false;" type="button" class="btn btn-success">Synchronize</a> +- </div> +- </div> +- </div> +- </div> +- + <div class="modal fade" id="deleteRegistryModal" tabindex="-1" role="dialog" aria-labelledby="deleteRegistryModalLabel"> + <div class="modal-dialog" role="document"> + <div class="modal-content"> +diff --git a/web/gui/src/dashboard.js/registry.js b/web/gui/src/dashboard.js/registry.js +index 090ef52f..a2322fb7 100644 +--- a/web/gui/src/dashboard.js/registry.js ++++ b/web/gui/src/dashboard.js/registry.js +@@ -3,25 +3,14 @@ + + NETDATA.registry = { + server: null, // the netdata registry server +- isCloudEnabled: false,// is netdata.cloud functionality enabled? +- cloudBaseURL: null, // the netdata cloud base url + person_guid: null, // the unique ID of this browser / user + machine_guid: null, // the unique ID the netdata server that served dashboard.js + hostname: 'unknown', // the hostname of the netdata server that served dashboard.js + machines: null, // the user's other URLs + machines_array: null, // the user's other URLs in an array + person_urls: null, +- anonymous_statistics_checked: false, + MASKED_DATA: "***", + +- isUsingGlobalRegistry: function() { +- return NETDATA.registry.server == "https://registry.my-netdata.io"; +- }, +- +- isRegistryEnabled: function() { +- return !(NETDATA.registry.isUsingGlobalRegistry() || isSignedIn()) +- }, +- + parsePersonUrls: function (person_urls) { + NETDATA.registry.person_urls = person_urls; + +@@ -75,26 +64,8 @@ NETDATA.registry = { + NETDATA.registry.hello(NETDATA.serverDefault, function (data) { + if (data) { + NETDATA.registry.server = data.registry; +- if (data.cloud_base_url !== "") { +- NETDATA.registry.isCloudEnabled = true; +- NETDATA.registry.cloudBaseURL = data.cloud_base_url; +- } else { +- NETDATA.registry.isCloudEnabled = false; +- NETDATA.registry.cloudBaseURL = ""; +- } + NETDATA.registry.machine_guid = data.machine_guid; + NETDATA.registry.hostname = data.hostname; +- if (!NETDATA.registry.anonymous_statistics_checked) { +- NETDATA.registry.anonymous_statistics_checked=true; +- if (data.anonymous_statistics) { +- (function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start': +- new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0], +- j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=false;j.src= +- 'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f); +- })(window,document,'script','dataLayer','GTM-N6CBMJD'); +- dataLayer.push({"anonymous_statistics" : "true", "machine_guid" : data.machine_guid}); +- } +- } + NETDATA.registry.access(2, function (person_urls) { + NETDATA.registry.parsePersonUrls(person_urls); + }); +@@ -143,12 +114,8 @@ NETDATA.registry = { + let name = NETDATA.registry.MASKED_DATA; + let url = NETDATA.registry.MASKED_DATA; + +- if (!NETDATA.registry.isUsingGlobalRegistry()) { +- // If the user is using a private registry keep sending identifiable +- // data. +- name = NETDATA.registry.hostname; +- url = NETDATA.serverDefault; +- } ++ name = NETDATA.registry.hostname; ++ url = NETDATA.serverDefault; + + console.log("ACCESS", name, url); + -- 2.30.0
guix-patches <at> gnu.org
:bug#46435
; Package guix-patches
.
(Thu, 11 Feb 2021 08:15:01 GMT) Full text and rfc822 format available.Message #8 received at 46435 <at> debbugs.gnu.org (full text, mbox):
From: Léo Le Bouter <lle-bout <at> zaclys.net> To: 46435 <at> debbugs.gnu.org Subject: Re: [PATCH] gnu: Add netdata. Date: Thu, 11 Feb 2021 09:14:21 +0100
[Message part 1 (text/plain, inline)]
I would need help to write a service for it. Here's the systemd service for it: https://salsa.debian.org/debian/netdata/-/raw/master/system/netdata.service.in Thank you
[signature.asc (application/pgp-signature, inline)]
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.