Weiter zum Inhalt

Off Topic

3.3k Themen 51.1k Beiträge
Hier kann über alles geredet werden was sonst nirgendwo hinpasst

NEWS

Unterkategorien


  • 107 Themen
    2k Beiträge
    Thomas BraunT
    @da_Woody Dann schleppt mobaxterm da wohl einen vollen X-Server mit an. Warum auch immer. Offenbar tunneln die da eine X-Session über SSH.
  • 260 4k
    260 Themen
    4k Beiträge
    Meister MopperM
    @bloop Ich bin von v13 erstmal wieder zurück auf v12.4+. Bisher hatte ich bei jedem Major Release breaking changes Probleme, die erst mit einem vX.1 behoben wurden. Um das Major Upgrade zu verhindern und trotzdem die neuen Versionen des aktuellen Zweiges bekommen, habe ich eine *.pref Datei in /etc/apt/preferences.d erstellt. Das funktioniert, und ich lasse mir von GitHub die Änderungen der Grafana releases zumailen, und schaue, was sich tut. Ja, das ist jetzt auch mal ein Plädoyer dafür, dass man nicht immer (ohne Sicherheitshintergrund!) sofort auf die nächste Major springen muss.
  • 153 3k
    153 Themen
    3k Beiträge
    HomoranH
    @iceman8080 dann sollten höchstens noch bei Neustart der influx-instanz Einträge mit influxdb als Quelle auftreten. Alles andere müsste javascript als Quelle angeben
  • Fragen und Hilfe zur externen SQL Datenbank

    1 5
    1 Themen
    5 Beiträge
    fuzzy1955F
    Teil 5: Verwenden der SQL-Daten in Diagrammen bzw. im VIS-2 Der Hauptzweck der Datenhistorisierung liegt natürlich in der grafischen bzw. tabellarischen Darstellung, um daraus mögliche Entscheidungen abzuleiten, etwa wo setzte ich beim Börsenstrompreis mein Bezugslimit. Eine einfache Möglichkeit zur grafischen Darstellung bieten die DIAGRAMME. Man wählt als Datenquellen die gewünschten SQL-Historisierungspunkte, stellt noch ein paar Dinge ein und … fertig. [image: 1770367644381-664a0f95-2fc3-48ae-babe-1a8ffafab1ad-image.png] Um das Ganze im VIS-2 anzuzeigen, nimmt man dort das Widget „Basic -IFrame“ und gibt bei Allgemein – Quelle den Link aus den Diagrammen an. [image: 1770367662940-281a33d1-fcdc-49bb-a3d9-c0fb7ea8ecd1-image.png] So kann man sich ein VIS-2-View nur für Diagramme bauen, bei der die gewünschte Art des Diagrammes angetippt wird: [image: 1770367682322-9328d9e4-3448-4e5a-8c92-8eeec3f2b52c-image.png] Die tabellarischen Darstellung im VIS-2 geschieht mit dem Widget „Basic Table“, bei dem man einen separaten Datenpunkt (Table Object ID) mit JSON-Daten befüllt. Dieses Beispiel zeigt Tages-, Monats- und Jahreswerte einer Strombilanz untereinander. [image: 1770367711812-00a9e22f-d74a-43e7-982f-0e35c37db84a-image.png] Die Datenpunkte dazu: { "alias.0.Diagrammdaten.StrombilanzJahre": { "common": { "name": "StrombilanzJahre", "desc": "Manuell erzeugt", "role": "state", "type": "json", "read": true, "write": true, "alias": { "id": "javascript.0.variables.j006" } }, "type": "state", "native": {}, "_id": "alias.0.Diagrammdaten.StrombilanzJahre", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" }, "val": "", "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1768340995710, "ack": false }, "alias.0.Diagrammdaten.StrombilanzMonate": { "common": { "name": "StrombilanzMonate", "desc": "Manuell erzeugt", "role": "state", "type": "json", "read": true, "write": true, "alias": { "id": "javascript.0.variables.j005" } }, "type": "state", "native": {}, "_id": "alias.0.Diagrammdaten.StrombilanzMonate", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" }, "val": "", "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1768340995710, "ack": false }, "alias.0.Diagrammdaten.StrombilanzTage": { "common": { "name": "StrombilanzTage", "desc": "Manuell erzeugt", "role": "state", "type": "json", "read": true, "write": true, "alias": { "id": "javascript.0.variables.j004" } }, "type": "state", "native": {}, "_id": "alias.0.Diagrammdaten.StrombilanzTage", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" }, "val": "", "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1768340995710, "ack": false } } Mit einem Javascript werden die Datenpunkte zeitgesteuert befüllt. strSQL = "SELECT DATE_FORMAT (tag, '%Y-%m-%d') AS Tag, " + "ROUND(SUM(pv) / 1000.0,1) AS PV, " + "ROUND(AVG(akku)) AS Hausakku, " + "ROUND(SUM(haus) / 1000.0,1) AS Haus, " + "ROUND(SUM(eauto) / 1000.0,1) AS eAuto, " + "ROUND(SUM(gen) / 1000.0,1) AS Gen, " + "ROUND(SUM(nots) / 1000.0,1) AS Nots, " + "ROUND(SUM(gesamt) / 1000.0,1) AS gesamt, " + "ROUND(COUNT(autark)) AS autark " + "FROM iobroker.tagesstatistik " + "GROUP BY DATE_FORMAT (tag, '%Y-%m-%d') " + "ORDER BY DATE_FORMAT (tag, '%Y-%m-%d') desc;"; sendTo('sql.0', 'query', strSQL, function (result) { if (result.error) { console.error(result.error); } else { MyTrigger (idStrombilanzTage,JSON.stringify(result.result)); } }); --------------------------- Voila , das war die ganze Zauberei --------------------------- Anregungen, Fragen etc. bitte hier anhängen.
  • 276 Themen
    5k Beiträge
    ubeckerU
    @MartinP Ich habe jetzt bei mit 2 Stück ESP32 S3 ETH in Betrieb. Einen für analoge Werte den anderen als 8fach Relais mit Timer. Allerdings habe ich die Software dazu so weit wie möglich selbst geschrieben. (Librarys außen vor) Da ich kein W-Lan wollte direkt per LAN angebunden. Per MQTT dann in IOBroker. Eine kleine Web-UI hab ich auch dazu gebastelt. Läuft absolut gut. Die Relaiskarte ist allerdings erst 2 Wochen online. Das analoge Teil jetzt 1 Monat. Da ich in dem analogen Teil etliche Berechnungen drin habe war auch meine Befürchtung das die Leistung nicht ausreicht. Im Hintergrung laufen dann noch ADC und DAC mit einer eigenen Soft SPI. (die interne habe ich nicht zum laufen gebracht) Mit 4Mikrosekunden Takt. Ich habe nicht gemessen wie schnell die antwortzeiten sind, aber eine Änderung im IOBroker für den analogwert ist gefühlt sofort da. Ausgabe des analogen Wert und Anzeige auf der Web-UI. Denke der ist noch weit weg von ausgelastet.
  • 196 6k
    196 Themen
    6k Beiträge
    ilovegymI
    danke für den hinweis, funktioniert hier auch besser als vorher.. ( vorher war mehr failover als balancer..)
  • Fragen zu Docker-Installationen

    23 342
    23 Themen
    342 Beiträge
    Marc BergM
    @juggi1962 sagte: Falls jemand eine Andere Erklärung dafür hat, bitte gern hier kund tun Du musst noch einen weiteren Container-Port freigeben, damit die Erfolgsmeldung angezeigt wird. Steht auch so in der Backitup Anleitung / Wiki. https://github.com/simatec/ioBroker.backitup/blob/master/docs/de/backitup.md#docker-unterstützung
  • 55 730
    55 Themen
    730 Beiträge
    DasBo1975D
    @MartinP Tatsächlich finde ich die Angst ob das Forum genutzt wird oder nicht, bezugnehmend auf die KI Implementierung, nicht wirklich groß. Denn in meinen Augen, ob ich nun im KI Chatfenster die Frage stelle oder einer KI die im Browser geöffnet oder in irgendeiner App läuft, ist egal. Jemand der die KI nutzt, egal auf welchen wegen, wird dieses tun. Und jemand der ohnehin gerne im Forum unterwegs ist, wird es auch bleiben. Vielleicht wäre es sogar interessant, solche Dinge zu vermischen. Nicht das die KI für den Nutzer ins Forum schreibt, aber vielleicht auf die Post die der User angelegt hat, reagiert und in iobroker selber Datenpunkte befüllt. Sowas wie. Ey, im Forum hast du 2 neue Antworten. So in der Form. Somit wäre das Forum indirekt, für den der es nutzen würde, mit im Broker. PS: Hatte diesen Text noch im ersten Post gehabt bevor er aufgeteilt wurde
  • Grafana im VIS anzeigen

    Verschoben
    5
    1
    0 Stimmen
    5 Beiträge
    498 Aufrufe
    HumidorH
    @crunchip habs damit geschafft, danke
  • (Gelöst) Ubiqiti Edgerouter-10x : Wo finde ich snmp OIDs ?

    edgemax oid snmb
    8
    0 Stimmen
    8 Beiträge
    355 Aufrufe
    amg_666A
    @martinp Richtig, und dann kann das in der vis z.B. so aussehen :-) [image: 1685893359552-f440d0b3-7c3b-4caf-b5b9-70caa4b91c63-grafik.png]
  • IOBroker als rundsteuerempfänger um die Power Wall zusteuern

    Verschoben
    29
    0 Stimmen
    29 Beiträge
    3k Aufrufe
    zeveroxZ
    @thebam Ich weis nicht was Meister und Slave heist ich habe nur in der Berufsschule die Basics wie Wende Schütz Schaltung oder Stern Dreieck
  • Influxdb2 Verwendung von Variablen

    Verschoben
    5
    0 Stimmen
    5 Beiträge
    412 Aufrufe
    D
    @marc-berg Natürlich kann ich alle Tasks bei der Umstellung editieren. Naja, es ist eher Faulheit oder Angst, einen Task zu vergessen. Ich habe es gerade probiert, mit Secrets würde es gehen. Aber ich hatte gehofft, es ginge einfach mit Variablen, die sind lesbar, Secrets-Values nicht. Aber durch die Version mit Secrets habe ich eine Lösung gefunden die es "einfacher" macht, dann alles zu editieren: ich lege die Bucket-Namen am Beginn der Query selbst als Variable an und verwende sie in der Query. So sind die Änderungen alle am Beginn des Tasks zu machen und können leicht mit Copy/Paste überschrieben werden. Aber am elegantesten wäre es doch, es nur einmal einzustellen und zack, alle Tasks nehmen die neuen Werte.
  • Kamera blendet sich selbst

    Verschoben kamera bild
    3
    0 Stimmen
    3 Beiträge
    749 Aufrufe
    ChaotC
    @mcu Danke dir. Ich dachte ich habe das alles schon abgearbeitet, aber eventuell liegt es ja tatsächlich an der zu großen Neigung der Kamera. Mal schauen ob ich den Gummiring etwas dichter bekomme.
  • Ftp-Server installieren

    Verschoben ftp-server
    3
    0 Stimmen
    3 Beiträge
    998 Aufrufe
    S
    Ich grab den alten Thread nochmal aus … ich weiß, dass es nicht direkt mit dem ioBroker zu tun hat, vielleicht kann man mir hier dennoch helfen . Ich hab mir in Proxmox ProFTPD in einem LXC aufgesetzt. Dann habe ich zwei User angelegt , die jeweils ihr Home-Verzeichnis in /var/Bilder/User1 bzw. User2 haben . bin nach dieser Anleitung vorgegangen (https://www.bennetrichter.de/anleitungen/ftp-server-linux/) Ich wollte per PhotoSync die Fotos von mir und meiner Frau in den jeweiligen Home-Verzeichnissen ablegen, allerdings soll User1 auch die Bilder von User2 sehen können und umgekehrt, so dass man letztlich auf alle Bilder Zugriff hat. Aktuell haben wir uns die Bilder per WhatsApp zugeschickt , was aber deutliche Einbußen in der Qualität hat. Wie stelle ich das an ? Aktuell sehe ich per FileZilla nur die Daten des jeweiligen Users .
  • [gelöst] InfluxDB - Flux Durchschnitt mehrere Datenpunkte

    3
    0 Stimmen
    3 Beiträge
    1k Aufrufe
    B
    @dp20eic Vielen Herzlichen Dank! Hat Funktioniert! Jetzt versehe ich auch endlich wofür da yield() eigentlich steht. :man-facepalming:
  • Grafana Pie-chart mit mehreren Values je Kuchenstück

    Verschoben
    1
    3
    0 Stimmen
    1 Beiträge
    203 Aufrufe
    Niemand hat geantwortet
  • Suche Zigbee Switch m. Dauerstrom + schaltbarer Phase

    Verschoben
    13
    0 Stimmen
    13 Beiträge
    1k Aufrufe
    M
    Was haltet ihr von dem? https://www.amazon.de/MHCOZY-einstellbare-Selbstsperrung-Momentanbetrieb-funktioniert/dp/B0BCFB5927/ Hat 230v eingang also kein trafo nötig und hat schon ein Gehäuse.
  • Mod-Bus Signal vom IR-Lesekopf (Tasnmota) generieren.

    Verschoben ehz lesekopf
    1
    0 Stimmen
    1 Beiträge
    174 Aufrufe
    Niemand hat geantwortet
  • Grafan: kw in Watt

    5
    1
    0 Stimmen
    5 Beiträge
    650 Aufrufe
    haus-automatisierungH
    @endurance sagte in Grafan: kw in Watt: Der wert ist aber in kwh. Kann ich diesen in Grafana in Watt umwandeln, Du meinst kW zu W? Ja, direkt im Flux Statement mit map. |> map(fn: (r) => ({r with _value: r._value * 1000.0}))
  • 24h-Verteilung des Verbrauchs über 1 Jahr in Grafana

    Verschoben
    12
    1
    0 Stimmen
    12 Beiträge
    1k Aufrufe
    W
    @ullij Hi, das war es nicht wonach ich suchte. Ich habe es jetzt herausgefunden. Ich habe es jetzt so gelöst, dass ich einen Datenpunkt im Format number angelegt habe und in InfluxDB speichern lasse im Skript bei jedem Aufruf alle historischen Daten lösche im Skript 24 Daten (prozentualer Verbrauch zu dieser Tageszeit) speichere (und das "from" des Datenpunkts missbrauche um meinen eigenen Text/Beschreibung zu dem entsprechenden Wert/Verbrauch zu speichern) in Grafana sowohl das "from" als auch "value" in einem Table anzeigen lasse (und die echte Zeit ausblende) So siehts jetzt in Grafana aus: [image: 1685578205195-33fb0238-980e-4184-8c43-78926abfa18f-grafik.png] Das ist das Skript (JS-export vom blockly): Spoiler var wert, ende, anfang, wert_prozentual, stundenanalyse, anzahl_datensaetze, i, result, zeit, stunde, j, zeitstempel, ursprung; function listsRepeat(value, n) { var array = []; for (var i = 0; i < n; i++) { array[i] = value; } return array; } // Statistik nach Tageszeit sortiert // Timeshift in Tagen [0] ende = parseFloat((new Date().getTime())) - parseFloat(0) * 86400000; // Dauer in Tage [7] anfang = parseFloat(ende) - parseFloat(7) * 86400000; wert_prozentual = listsRepeat(0, 24); sendTo("influxdb.0", "getHistory", { "id": 'javascript.0.energycounter.ec_pulses', "options": {start: anfang, end: ende, aggregate: "none"} }, async function (result) { stundenanalyse = listsRepeat(0, 24); anzahl_datensaetze = getAttr(result, 'result').length; var i_end = parseFloat(anzahl_datensaetze) - 1; var i_inc = 1; if (0 > i_end) { i_inc = -i_inc; } for (i = 0; i_inc >= 0 ? i <= i_end : i >= i_end; i += i_inc) { // .val=value .ts=timestamp zeit = getAttr(result, (['result.',i,'.ts'].join(''))); stunde = getDateObject(zeit).getHours(); // Analyse in welcher Stunde des Tages der Energiepuls kam stundenanalyse[((parseFloat(stunde) + 1) - 1)] = parseFloat(stundenanalyse[((parseFloat(stunde) + 1) - 1)]) + 1; } console.log((['Tagesstatistik vom ',formatDate(getDateObject(anfang), "JJJJ.MM.TT SS:mm:ss.sss"),' bis ',formatDate(getDateObject(ende), "JJJJ.MM.TT SS:mm:ss.sss")].join(''))); for (i = 0; i <= 23; i++) { wert = stundenanalyse[((parseFloat(i) + 1) - 1)]; wert_prozentual[((parseFloat(i) + 1) - 1)] = Math.round((parseFloat((parseFloat(wert) / anzahl_datensaetze)) * 100)*10)/10; console.log(([i,' Uhr: ',wert_prozentual[((parseFloat(i) + 1) - 1)],' %'].join(''))); } // Jetzt wird die Statistik in InfluxDB geschrieben sendTo("influxdb.0", "deleteAll", { "id": 'javascript.0.test.statistiker' }); for (j = 0; j <= 23; j++) { zeitstempel = parseFloat(1685311202800) + parseFloat(j) * 60000; wert = wert_prozentual[((parseFloat(j) + 1) - 1)]; console.log(('Ergebnis der Anbfrage: ' + String(wert))); ursprung = String(('' + j)) + ' Uhr'; sendTo("influxdb.0", "storeState", { "id": 'javascript.0.test.statistiker', "state": {ts: zeitstempel, val: wert, ack: false, from: ursprung} }, async function (result) { // Rückmeldung von influxDB ausgeben: }); } }); Die zwei Queries in Grafana: SELECT "from" FROM "autogen"."javascript.0.test.statistiker" WHERE $timeFilter SELECT "value" FROM "autogen"."javascript.0.test.statistiker" WHERE $timeFilter Und hier die anderen Einstellungen (overrides und transformations) in Grafana: [image: 1685578684329-ea635dd2-270a-4690-8e64-e19f069e4483-grafik.png] Wieso schreibe ich das so ausführlich? Vielleicht ist es ja auch für andere Leute interessant: Grafana zur Visualisierung der Iobroker-Daten zu nutzen -> Grafana kann man auf dem PC installieren und so Ressourcen beim Iobroker-Rechner (zB Raspberry 1b bei mir) sparen Beliebigen Text (zB. der letzte Emailabsender, die letzte Zeile der Iobroker-Log-Datei oder einen Zufallstext zur Begrüßung) im Grafana-Dashboard anzuzeigen (ist im Skript die Kategorie zB. "7 Uhr") Viel Spass damit! :-)
  • Proxmox VM, Bluetooth Dongle USB Probleme

    16
    4
    0 Stimmen
    16 Beiträge
    991 Aufrufe
    crunchipC
    @akwole sagte in Proxmox VM, Bluetooth Dongle USB Probleme: mit dem neuen BLT-Dongle läuft der Adapter unter Proxmox nun endlich, so das er auch Geräte finden kann dann lag es wohl doch am Stick
  • ESP32 mit Ethernet, Flash Probleme

    Verschoben
    6
    0 Stimmen
    6 Beiträge
    2k Aufrufe
    michl75M
    @martinp haaaaa ... Endlich! :) Mit Tasmota und der eben geschriebenen Anleitung habe ich es endlich geschafft !! Vielen vielen Dank !! ... @martinp said in ESP32 mit Ethernet, Flash Probleme: zwischen IO0 und GND tritt die Fehlermeldung "espcomm_upload_mem failed" nicht mehr auf? Doch diese Meldung ist vorher mit der Bin-Datei von ESPEasy immer gekommen. Jetzt habe ich wie oben gerade geschrieben, mir dem Flash Download Tool Tasmota draufgeklatscht. Zack, auf einmal war Wlan da, konnte mich anmelden und Wlan Pass usw eingeben. Dann über Wlan IP angemeldet und Eth-Kabel dran und zack konnte einstellen. Es kam aber nicht mit der Tasmota-"Software". So nun habe ich Tasmota drauf, das erste mal das ich mich (not gedrungen) damit beschäftigen muss. Daran soll dann nämlich ein Windsensor, ein Helligkeitssensor und ein BMP280 für Temperatur, Feuchtigkeit und Luftdruck + noch einen Tauchtemperatursensor. Mal sehen was das noch wird... Auf jeden Fall möchte ich mich bedanken! Habe ja seit Tagen da rumprobiert ... aber immerhin jetzt ein Erfolg.
  • Darstellung kWh vom Stromzähler

    Verschoben
    5
    5
    0 Stimmen
    5 Beiträge
    587 Aufrufe
    B
    @marc-berg sagte in Darstellung kWh vom Stromzähler: @burningbaer sagte in Darstellung kWh vom Stromzähler: Auch noch OK, aber wenn ich jetzt die Unit bei Grafana eingebe macht er mir alles durcheinander: Wieso "durcheinander"? 1900 kWh sind 1,9 Megawattstunden. Grafana rechnet korrekt. Für deine Anforderung könntest du eine "Custom Unit" eingeben, dann wird nur angezeigt und nicht versucht zu rechnen: [image: 1685361944559-1937451b-e418-4dd6-9a88-cfd634c97025-grafik.png] So hat es aber geklappt! Danke!
  • 2te USV am USB Port bei NUC

    Verschoben nut usv ups
    27
    0 Stimmen
    27 Beiträge
    2k Aufrufe
    W
    @digi-bit sagte in 2te USV am USB Port bei NUC: @homoran sagte in 2te USV am USB Port bei NUC: @digi-bit sagte in 2te USV am USB Port bei NUC: alles völlig uninteressant wäre halt möglicherweise einfacher als einen Server auf 2 USV zu trimmen. Sehe ich ehrlich gesagt anders..... ein Server und 2 USVs überwachen ist einfacher wie 2 Server, wenn man weiß wie ^^ aber Ansichts Sache mfg Nö, normalerweise wird die USV von dem Gerät überwacht, welches es im Notfall mit Strom versorgen soll. Denn nur so ist ja auch sichergestellt, dass das Gerät sauber runterfährt, wenn die USV leer wird. Auf welche USV soll der Server denn reagieren, wenn sie leer wird, wenn zwei an einem Server hängen? Ich habe hier im Haus 4 USV verteilt. Zwei hängen je an einer Synology Diskstation, und die anderen zwei je an einem NUC, die im Proxmox-Cluster-Verbund laufen. Die zwei Diskstation und die zwei NUC reagieren jeweils auf die USV, an der sie auch hängen. Die Werte der USV kommen an vier Instanzen des NUT-Adapters in iobroker an. Der läuft auf einem der NUC und wird somit im Notfasll sauber mit runtergefahren. Warum ich da zwei, drei oder alle 4 USV an einen Server hängen sollte, um die Werte in iobroker zu bekommen, erschließt sich mir absolut nicht. Gruss, Jürgen
  • TASMOTA: Ausschalten für einige Sekunden klappt nicht

    Verschoben
    7
    0 Stimmen
    7 Beiträge
    675 Aufrufe
    I
    @wal: Es funktioniert! Einen herzlichen Dank! :-) Da habe ich die Rule-Doku offenbar noch nicht genau genug gelesen.
  • Suche skript für mtk 175 mit strompreise Anzeige etc

    Verschoben
    16
    0 Stimmen
    16 Beiträge
    457 Aufrufe
    HomoranH
    @david-koch sagte in Suche skript für mtk 175 mit strompreise Anzeige etc: @homoran kann dennoch geholfen werden oder eher nicht? denn was? @homoran sagte in Suche skript für mtk 175 mit strompreise Anzeige etc: dann braucht es auch alle notwendigen Informationen!
  • FritzBox: Freigabe alter IP-Adressen

    Verschoben
    43
    0 Stimmen
    43 Beiträge
    11k Aufrufe
    I
    @fichte Danke, aber nein. Ich habe nur 10 IP-Adressen für DHCP aktiviert und für alle „festen“ Geräte IP-Adressen außerhalb dieser Range vergeben.
  • Kleinster Tür/Fenstersensor

    5
    0 Stimmen
    5 Beiträge
    278 Aufrufe
    G
    @martinp Das wäre möglicherweise auch eine Variante! Gute Idee - das muss ich mir bei Gelegenheit direkt mal anschauen. Vielleicht geht da was. Danke für die Idee!

279

Online

32.9k

Benutzer

83.2k

Themen

1.3m

Beiträge