StableNet-Abfragen
Dieser Abschnitt gilt nur für Systeme, die in StableNet® integriert sind.
StableNet®-Daten können sowohl aus einem aggregierten Datensatz in einer lokalen SKOOR-Datenbank als auch in Echtzeit über die StableNet®-API abgefragt werden. Die folgenden Richtlinien helfen dabei, diese beiden Methoden zu kombinieren und zu optimieren.
Erstellen Sie eine materialisierte Datenabfrage für Geräte und Messungen
Die folgende Beispielabfrage liefert Basisdaten für die Verwendung mit einem FilterMatrix-Widget (z. B. Filter für Geräte oder Messungen) sowie zum Verknüpfen von Messdaten aus der StableNet®-API oder der aggregierten Datentabelle. Die Datenquelle muss auf einen Typ von StableNet eingestellt sein.
-- Data query example "device_measurement" SELECT std.id AS device_id, std.display_name AS device_name, sm.id as measurement_id, sm.name as measurement_name FROM stablenet_taggable_device std JOIN stablenet_measurement sm ON std.id = sm.dest_device_id
Da sich Geräte- und Messdaten nicht sehr oft ändern, sollte diese Abfrage materialisiert werden. Dadurch wird die Leistung erheblich gesteigert.
Stellen Sie das Aktualisierungsintervall auf täglich ein und erstellen Sie Indizes für alle Attribute:
Fremdtabelle für Echtzeitdaten verknüpfen
Zusätzlich zu der vorbereiteten materialisierten Datenabfrage können Daten aus der StableNet®-API mithilfe einer Fremdtabelle verknüpft werden.
Das FROM-Schlüsselwort im folgenden Beispiel verweist auf die oben vorbereitete materialisierte Abfrage.
SELECT
dm.device_id,
dm.device_name,
dm.measurement_name,
dm.measurement_id,
sma.metric_key,
sma.metric_name,
sma.interval,
sma.min,
sma.max,
sma.avg,
sma.timestamp
FROM device_measurement dm
JOIN stablenet_measurement_data sma
ON dm.measurement_id = sma.measurement_id
WHERE sma.start = ${begin}::timestamptz
AND sma."end" = ${end}::timestamptz
AND sma.bucket_size = EXTRACT(
EPOCH FROM ('1 ' || ${bucket_size})::interval
)::integer
AND sma.metric_name = ${metric_name}
Im Dashboard oder in der Datenvorschau müssen für diese Beispielabfrage die folgenden Attribute festgelegt werden:
begin/end: ISO 8601-Zeitstempel, z. B. 2024-05-01T00:00:00Z
bucket_size: Zeitbucket in Worten wie Stunde, Tag, Monat usw.
metric_name: Ein gültiger StableNet®-Metrikname wie Round Trip Time
Anstelle des Attributs metric_name können Sie das Attribut metric_key in der WHERE-Klausel verwenden, um eine bestimmte Metrik auszuwählen, wenn mehrere verfügbar sind.
Aggregierte Datentabelle verbinden
Wenn die Leistung wichtiger ist als Echtzeitdaten, sollte die aggregierte Datentabelle den Fremdtabellen vorgezogen werden.
Das FROM-Schlüsselwort im folgenden Beispiel verweist auf die oben vorbereitete materialisierte Abfrage.
SELECT
dm.device_id,
dm.device_name,
dm.measurement_name,
dm.measurement_id,
sma.metric_key,
sma.metric_name,
sma.interval,
sma.min,
sma.max,
sma.avg,
sma.timestamp
FROM device_measurement dm
JOIN stablenet_measurement_data_aggregated sma
ON dm.measurement_id = sma.measurement_id
WHERE sma.timestamp BETWEEN ${begin}::timestamptz AND ${end}::timestamptz
AND sma.metric_name = ${metric_name}
Im Dashboard oder in der Datenvorschau müssen für diese Beispielabfrage die folgenden Attribute festgelegt werden:
begin/end: ISO 8601-Zeitstempel, z. B. 2024-05-01T00:00:00Z
metric_name: Ein gültiger StableNet®-Metrikname wie Round Trip Time
Anstelle des Attributs metric_name können Sie das Attribut metric_key in der WHERE-Klausel verwenden, um eine bestimmte Metrik auszuwählen, wenn mehrere verfügbar sind.
Fremdtabellen
Name | Felder | Qualifizierer |
|---|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Obwohl measurement_id und metric_key optional sind, wird es nicht empfohlen, Abfragen ohne diese durchzuführen. Dadurch werden die Messdaten aller Messungen und aller Metriken gelesen, was sehr lange dauern kann und den StableNet-Server stark belastet. Nur für sehr kurze Zeiträume < 1 Stunde empfehlenswert. Wenn mehrere Messungen und Metriken benötigt werden, sollte die Tabelle stablenet_measurement_data_aggregated verwendet werden.
Aggregierte Messdaten
Aggregiert nach Stunden, wird automatisch stündlich aktualisiert. Kann verwendet werden, um Analyseabfragen über einen großen Bereich von Messungen und über große Zeiträume durchzuführen.
Im Grunde handelt es sich um eine Timescale-Hypertabelle (https://docs.timescale.com/ ). Die Chunk-Größe beträgt 7 Tage, Chunks werden nach 7 Tagen komprimiert.
Name | Felder |
|---|---|
|
|
stablenet_measurement_data_aggregated Enthält nur Daten für konfigurierte Metrikschlüssel.


