Dashboard, Dashboard an der Wand

Ein datenreiches Monitoringsystem auf Basis von Pixelbildschirmen: Eine der schönen, greifbaren Ideen die uns seit Star Trek durch den Kopf geht. Mit einem Blick auf die Wand bekommt der Betrachter Auskunft über die aktuelle Situation. Also die Datenleitungen, Ressourcenverbrauch und alles, was wir zu Betreiben eines Hackspaces wissen wollen.

Dort sollten Informationen in Zahlenwerten und im zeitlichen Verlauf als Graphen angezeigt werden. Üblichwerweise handelt es sich hier um Informationen wie Auslastung der Rechner und Zugriffsstatistiken für Dienste. So lassen sich hiermit alle möglichen Informationen speichern; eben alles, was sich messen lässt. Wir schlagen hiermit die Brücke zwischen den beiden Trends “Big Data” und Automation.

Dashboard

Das können wir auch im Kleinen probieren. So haben wir erst einmal einen Dienst zum Sammeln der Daten aufgesetzt. Das Projekt Graphite ist eine Freie Software, die auf einem virtuellen Server im Chaosdorf läuft. Über ein simples Protokoll nimmt der – in Python realisierte – Dienst Messwerte an und speichert sie in einer speziellen Datenbank.

Dort werden die Messwerte chronologisch gespeichert und langfristig in immer gröberen Zeitschritten archiviert. Damit ist es möglich, sekundengenaue Auskunft über die vergangenen Tage zu erhalten und länger zurückliegende Daten in Minuten zusammenzufassen, um die Größe der Datenmenge zu begrenzen.

Graphite gibt die Daten in frei konfigurierbaren Graphen als Pixelgrafik (PNG) gerendert oder in maschinenlesbarer Form als JSON-Datei aus. Letzteres verwendet unsere Rauminstallation, die mittels der freien Web-Anwendung Team Dashboard realisiert wurde. Auch diese haben wir nicht selbst entwickelt, da wir uns gerade erst mit deren hochaktueller Technologie auseinandersetzen.

Team Dashboard bezieht die Daten und zeichnet Graphen direkt im Browser als Vektorgrafik (SVG). Dazu nutzt es einen HTML5-Canvas und die Bibliothek D3. Somit erscheinen die Graphen hochauflösend und sind auf dem Endgerät skalierbar. Da das Dashboard auf jedem Rechner im Chaosdorf angezeigt werden kann, sicherlich von Vorteil.

Zudem können ohne weitere Konfiguration am Server beliebig viele verschiedene Messreihen gespeichert werden. Von überall im lokalen Netzwerk werden Daten angenommen und gespeichert. Auf dem Dashboard können sie dann aufgearbeitet angezeigt werden. So entsteht kollaborativ eine Übersicht über die in den verschiedenen Projekten angefallenen Daten.

Derzeit werden folgende Informationen dargestellt – weitere Anzeigen sind geplant.

  • Internet-Traffic stromauf- und abwärts (Graph)
  • Anzahl der Endgeräte im Netzwerk (Zahl)
  • Uplink-Traffic unserer Freifunk-Node stromauf- und abwärts (Graph)
  • Anzahl der Freifunk-Nodes in der Düsseldorfer Community (Zahl)
  • Temperatur der Luft im Hackcenter (Graph/Zahl)
  • Öffnungs-Status der Chaosdoor, unserer Eingangstür (Graph/Zahl)
  • Verbleibende Überbrückungszeit der unterbrechungsfreien Stromversorgung (Graph)
  • Systemauslastung unseres Servers Hyperion (Graph)

DashPi

Die Rauminstallation besteht aus einem kleinen Rechner (Raspberry Pi), an den ein Bildschirm angeschlossen ist und der die Web-Anwendung darstellt. Dazu bootet er ein minimales Betriebssystem (Arch Linux) und startet ein Fenstersystem (awesome), auf dem im Vollbild der Web-Browser (luakit) angezeigt wird.

Der Rechner verfügt über eine GPIO-Stiftleiste, die programmierbar ist. An diese haben wir einen Temperatursensor per I2C-Protokoll angeschlossen. Dieser misst die Raumtemperatur mit einer Auflösung von 0,06 °C.

Die Daten werden sekündlich mit einem eigens entwickelten Werkzeug ausgelesen und übers Netzwerk übertragen. Auf dem Server empfängt StatsD die Daten per UDP und versieht sie mit einem Zeitstempel, bevor er sie alle zehn Sekunden gesammelt an Graphite weitergibt.

Daten per UDP ohne Zeitstempel übermitteln zu können, bedeutet für uns eine weitere Möglichkeit. Mikrokontroller mit minimaler Ausstattung können so Daten sammeln und verfügbar machen. Wir planen derzeit, den Temperatursensor neben anderen Sensoren auf einem eigenen Endgerät unterzubringen, das auf einer 8-Bit-Mikroarchitektur basiert.

Bis dahin sind wir noch damit beschäftigt, weitere sinnreiche Graphen zu spezifizieren. Dazu stellt Graphite Funktionen bereit, mit denen zeitliche Ableitungen, Skalierungen und andere Manipulationen möglich werden. Am Ende trauen wir eben keiner Satistik, die wir nicht selber gefälscht haben.

BB10 DEV Kickoff

Am 23.01.2013 trifft sich die neu gegründete „BlackBerry Developer Group Düsseldorf“ zum BB10 DEV Kickoff im Chaosdorf.

Wir planen uns über die Neuerungen von BB10 auszutauschen, gemeinsam die Entwicklungsumgebung zu erkunden und vielleicht auch schon bestehende Apps auf BB10 zu portieren.

Zudem konnten wir für unser erstes Treffen Kamel Lajili (Senior BlackBerry Application Development Consultant bei RIM) und Aron Ardiri (Senior Technical Evangelist bei RIM) als Experten und Sprecher gewinnen.

Dev Devices mit BB10 zum anfassen, ausprobieren und testen werden wir, ebenso wie vielleicht die ein oder andere Überraschung, vor Ort haben.

Interessierte Entwickler, Bastler und Hacker sind ebenso wie begeisterter Smartphone Anwender ohne Programmierkenntniss, herzlichst eingladen einfach vorbei zu kommen und sich uns anzuschließen. Eine Voranmeldung ist nicht nötig.