Projekt:graphs.k4cg.org

Aus k4cg.org
Projekt:graphs.k4cg.org
Betreuer*In noqqe
Jahr 2016
Läuft auf nixe.k4cg.org

Wir brauchen schon länger eine Möglichkeit anständige Graphen für all unsere Sensoren zu bauen. Dieses Projekt soll diese Möglichkeit nun bringen.

Setup

InfluxDB und Grafana. Daten werden per REST an InfluxDB geschickt.

InfluxDB

Läuft auf Port 8086 unter v6 auf der Nixe. Ist ausschliesslich über localhost erreichbar

Die NixOS Config auf Nixe für InfluxDB ist unspektakulär. Nur Services Enabled.

Grafana

Unter https://graphs.k4cg.org erreichbar. Intern unter Port 3000.

Es gibt momentan 2 Public Dashboards. Um die Graphen unter Stats einzubetten muss Anonymous Access erlaubt werden

https://graphs.k4cg.org/dashboard/db/besucher https://graphs.k4cg.org/dashboard/db/sensors


  services.grafana = {
    enable = true;
    protocol = "http";
    port = 3000;
    auth.anonymous.enable = true;
  };


Apache

      {
        documentRoot = "/var/www/graphs.k4cg.org";
        port = 80;
        hostName = "graphs.k4cg.org";
        serverAliases = [ "www.graphs.k4cg.org" ];
        adminAddr = "xxx";
        extraConfig = ''
        Alias /.well-known/acme-challenge/ /var/www/challenges/
        <Directory /var/www/challenges/>
           AllowOverride None
           Require all granted
           Satisfy Any
        </Directory>
        '';
      }

      {
        documentRoot = "/var/www/graphs.k4cg.org/public";
        port = 443;
        enableSSL = true;
        sslServerCert = "/usr/local/acme-tiny/k4cg.org.crt";
        sslServerKey = "/usr/local/acme-tiny/k4cg.org.key";
        sslServerChain = "/usr/local/acme-tiny/intermediate.crt";
        hostName = "graphs.k4cg.org";
        serverAliases = [ "www.graphs.k4cg.org" ];
        adminAddr = "xxx";
        extraConfig = ''
        ProxyPass "/" "http://localhost:3000/"
        '';
      }

Collectors

Hier wird dokumentiert welche Daten wie zustande kommen, wie sie gesendet werden und wo man den Code dazu finden kann.

Die meisten Daten werden über das Skript https://github.com/k4cg/sensor-fetcher erfasst.

Licht

Momentane UV Werte in der CG werden über den Tischtennisschläger(tm) aus organic-entropy.org erfasst.


Die Werte sind meistens null, da der Sensor momentan sehr weit weg vom Fenster montiert ist. Ein Test wurde jedoch vollzogen mit einem geliehenen UV Strahler.

UVstrahler.jpg

Geraeusche

Die momentane Geräuschkulisse wird ebenfalls über den Noise Sensor von Tinkerforge an dem Tischtennisschläger(tm) erfasst.

Temperatur

Im Temperatur Graphen sind aktuell 3 verschiedene Daten enthalten.

1. Interner Temperatur Sensor

Temperatur Sensor von Tinkerforge der über sensor-fetcher erfasst wird.

2. Interner Temperatursensor

Waijb brachte einen weiteren Temperatursensor mit welcher an Scotty angeschlossen ist. Siehe [Host:scotty.intern.k4cg.org] unter 'Tempi'

3. Externer Temperatur Sensor

Über die API von wunderground wird die Außentemperatur in den Graphen eingepflegt. Hierzu ist nur ein REST Call nötig und wird emebfalls über sensor-fetcher erledigt.

Geraete in der CG

Die Netzwerk Geräte innerhalb der CG werden über das Projekt:openstatus abgefragt. Die bereits erstellte JSON Datei devices.json wird auch hier über sensor-fetcher abgefragt.

Besucherzaehlungen (manuell)

Die Besucherzaehlungen werden von Hand in der InfluxDB hinterlegt.

date +%s -d "last thursday"
1476914400
curl -i -XPOST 'http://localhost:8086/write?db=sensors' --data-binary "besucher besucher=15 1476914400000000000"

Früher oder später wird es hierfür ein Skript geben. --> Stats#Besucherzahlen_2

Ich will auch Graphen zeichnen

TODO. Bisher bei noqqe melden

InfluxDB 1.x auf 2.x Migration

Hier gibt es ein schoenes Diagramm, welche Systeme auf die InfluxDB zugreifen: https://k4cg.github.io/homeassi/docs/homeassi/communication-diagrams/images/k4cg-internal-communication.drawio.svg

InfluxDB 1.8.x does contain a forwards compatible API endpoint for this v2 API.

Influx Konfig:

http.auth-enabled = true
continuous_queries.enabled = true
Quelle Welche Daten Zieldatenbank Nutzer Library/Version Bemerkung Hinweise zur Migration
Telegraf (mqtt.intern.k4cg.org) sensors/# wip mqtt_telegraf Telegraf 1.13.3, Output Plugin influxdb Scheinbar Authentifizierung mit Username und Passwort (in der Konfig hinterlegt). Momentan aber alles kaputt (Fehler im Input und im Output Plugin). https://docs.influxdata.com/influxdb/cloud/write-data/no-code/use-telegraf/manual-config/ (influxdb_v2 Output Plugin verwenden)
Homeassistant Alle konfigurierten Sensoren, momentan nichts explizit ausgeschlossen home_assistant homeassi Momentan noch Konfiguration fuer InfluxDB 1.x. --- Doku: https://www.home-assistant.io/integrations/influxdb/
Promox VMs ({proxmox,beehive}.intern.k4cg) "various stats about your hosts, virtual guests and storages" proxmox proxmox (?) InfluxDB 1.x ueber UDP --- 2.x hat nur noch eine http(s) API. Umstellung der Proxmox Konfig auf http(s) API vor dem Upgrade schon moeglich, siehe https://pve.proxmox.com/wiki/External_Metric_Server. - sensor-fetcher (rumpl.k4cg.org) status.json (http://k4cgrouter.duckdns.org:59468/status.json) sensors sensorfetcher Package influxdb 5.2.2 (/usr/local/sensor-fetcher/.venv) Scheinbar Authentifizierung mit Username und Passwort (in /usr/local/sensor-fetcher/fetch.py hinterlegt). Package influxdb ist deprecated (https://github.com/influxdata/influxdb-python). Nachfolger fuer InfluxDB 2.x: https://github.com/influxdata/influxdb-client-python.