Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Off Topic
    4. Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern

    This topic has been deleted. Only users with topic management privileges can see it.
    • Marc Berg
      Marc Berg Most Active @bitwicht last edited by Marc Berg

      @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

      Nur was ist jetzt das Problem mit dem andren Bucket ?

      du bist nicht allein mit dem Prob: https://community.influxdata.com/t/influxdb-2-1-1-internal-server-error-timestamp-related/23994

      Abhilfe bietet wohl ein Umkopieren der gesamten Daten in ein neues Bucket, löschen des alten, wieder anlegen und zurückkopieren.

      from(bucket: "iobroker")
        |> range(start: -10y)
        |> to(bucket: "iobroker_tmp")
      
      1 Reply Last reply Reply Quote 0
      • B
        bitwicht last edited by bitwicht

        @Marc-Berg

        Habs gerade gelesen. In Beitrag schreibt aber jemand ich muss dann auch die Tokens neu anlegen ?

        Ich teste das mal.

        Ich lege ein neues Bucket an.
        Berechtige die Tokens auf das neue.
        Lösche das alte
        Lege das alte neue an
        Berechtige die Tokens vom neuen auf das "alte-neu-angelegte"

        Vielleicht kann ich die bestehendes Tokens so übernehmen

        Marc Berg 1 Reply Last reply Reply Quote 0
        • Marc Berg
          Marc Berg Most Active @bitwicht last edited by

          @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

          Habs gerade gelesen. In Beitrag schreibt aber jemand ich muss dann auch die Tokens neu anlegen ?

          Nein, das ist nicht so. Es sei denn, du hättest Bucket-bezogene Berechtigungen vergeben, was ich nicht glaube.

          1 Reply Last reply Reply Quote 0
          • B
            bitwicht last edited by bitwicht

            @marc-berg

            Ich hab den Befehl ausgeführt.

            IO-B42.JPG

            Allerdings sind im Bucket iobroker viel mehr measurements wie im iobroker_tmp.

            Er bleibt immer bei ca. 21s hängen - falls das % sein sollen

            IO-B43.JPG

            Den influx Adapter hatte ich beendet während er kopiert.

            Marc Berg 1 Reply Last reply Reply Quote 0
            • Marc Berg
              Marc Berg Most Active @bitwicht last edited by

              @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

              Er bleibt immer bei ca. 21s hängen - falls das % sein sollen

              Oh dear, schwere Geburt! 🙂

              Wahrscheinlich ist dein System zu langsam, um die Aktion innerhalb des Timeout-Zeitraums zu beenden. Du könntest jetzt Measurement für Measurement kopieren, indem du eine Filterbedingung einfügst:

              from(bucket: "iobroker")
                |> range(start: -10y)
                |> filter(fn: (r) => r["_measurement"] == "test")
                |> to(bucket: "iobroker_tmp")
              

              Hiermit kannst du alle Measurements inkl. der Anzahlen ausgeben lassen (wenn es denn dein System schafft):

              from(bucket: "iobroker")
              |> range(start: -10y)
              |> filter(fn: (r) => r["_field"] == "value")
              |> count()
              |> group()
              |> keep(columns: ["_measurement", "_value"])
              |> sort(columns: ["_value"], desc: true)
              |> rename(columns: {_value: "Anzahl"})
              
              1 Reply Last reply Reply Quote 0
              • B
                bitwicht last edited by

                @Marc-Berg

                Ohje, das sind ca. 120 measurements.
                Da bin ich ja fast am aufgeben 😞

                Wenn ich mich in die CLI auf der Shell einlese, ist da auch ein Timeout ?

                1 Reply Last reply Reply Quote 0
                • Marc Berg
                  Marc Berg Most Active last edited by

                  @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                  Wenn ich mich in die CLI auf der Shell einlese, ist da auch ein Timeout ?

                  Das muss serverseitg gemacht werden, d.h. in der config.toml. Müsste ich selbst googeln.

                  Wenn du dich mit Regex auskennst, könntest du auch mehrere Measurements in einer Abfrage selektieren. Z.B. das ganze Alphabet durch.

                    |> filter(fn: (r) => r["_measurement"] =~ /^A/)
                    |> filter(fn: (r) => r["_measurement"] =~ /^B/)
                  
                  1 Reply Last reply Reply Quote 0
                  • B
                    bitwicht last edited by bitwicht

                    @marc-berg

                    Das habe ich gefunden:

                    Hello, I bumped at this post since I wanted to do the same. In order to set longer timeout there are two settings that need to be configured: session-renew-disabled session-length Steps: In /etc/influxdb/config.toml file add: session-renew-disabled = true session-length = 1440 # session renewa…
                    

                    Das teste ich gleich mal.

                    Ich würde es auch mal per Shell versuchen.
                    Wäre das so richtig zusammengebaut:

                    sudo influx query --token xxxxxxxxxxxxxxxxxxxx 'from(bucket:"iobroker") |> range(start: 1970-08-28T22:00:00Z) |> to(bucket: "iobroker_tmp")'
                    
                    Marc Berg 2 Replies Last reply Reply Quote 0
                    • Marc Berg
                      Marc Berg Most Active @bitwicht last edited by

                      @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                      Ich würde es auch mal per Shell versuchen.
                      Wäre das so richtig zusammengebaut:

                      sieht gut aus.

                      1 Reply Last reply Reply Quote 0
                      • Marc Berg
                        Marc Berg Most Active @bitwicht last edited by

                        @bitwicht

                        Ich würde ja sagen, dass es am schnellsten ginge, das Bucket zu löschen und das Backup zurückzuspielen. Ich halte es aber nicht für unwahrscheinlich, dass der Fehler danach wieder drin steckt.

                        1 Reply Last reply Reply Quote 0
                        • B
                          bitwicht last edited by

                          @Marc-Berg

                          Backup geht wohl nicht, hat schon jemand gemacht.
                          Über die Shell läuft es seit 1 Minute.
                          Wenn nicht muss ich den Timeout in der Config hoch setzen oder deaktivieren.

                          1 Reply Last reply Reply Quote 0
                          • B
                            bitwicht last edited by

                            @Marc Berg

                            ich glaube das macht so keinen Sinn. Der Kopiert wohl noch 2 Tage ....
                            Ich merke gerade ich schreibe alle meine Datenpunkte nahezu pro Sekunde in die Influx.

                            Ich glaube ich muss die DB neu aufbauen mit diesen Downsampling-Bucket:
                            https://forum.iobroker.net/topic/58462/datenaufzeichnung-retention-influxdb-2-0/21

                            Marc Berg 1 Reply Last reply Reply Quote 0
                            • Marc Berg
                              Marc Berg Most Active @bitwicht last edited by Marc Berg

                              @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                              Ich merke gerade ich schreibe alle meine Datenpunkte nahezu pro Sekunde in die Influx.

                              Ja, das bricht wohl jeder Hardware irgendwann den Hals. Ich denke auch, in dieser Situation ist es das Beste, grundsätzlich neu anzufangen, die vorhandenen Daten aggregiert in ein anderes Bucket zu schreiben und sich zu überlegen, wie man schon ganz am Anfang die Datenflut begrenzen kann. Der Adapter bietet da ja einige Möglichkeiten.

                              1 Reply Last reply Reply Quote 0
                              • B
                                bitwicht last edited by bitwicht

                                @Marc-Berg

                                Immerhin, wieder etwas gelernt.

                                Wenn ich den Datenpunkt in die Influx schreiben lasse gibt es die Option: Blockzeit

                                Verstehe ich das richtig, dass ich hier 5 Min einstellen könnte und er dann nur alle 5 Minuten einen Wert wegschreibt auch wenn es davon eine Veränderung gab?

                                IO-B52.JPG

                                Damit könnte ich die Datenflut auch etwas eingrenzen.

                                Marc Berg 1 Reply Last reply Reply Quote 0
                                • Marc Berg
                                  Marc Berg Most Active @bitwicht last edited by

                                  @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                                  Verstehe ich das richtig, dass ich hier 5 Min einstellen könnte und er dann nur alle 5 Minuten einen Wert wegschreibt auch wenn es davon eine Veränderung gab?

                                  Das ist eine Möglichkeit, ja. Ich persönlich finde es besser, den Haken "Nur Änderungen aufzeichnen" zu setzen und zusätzlich ausschließlich die minimale Differenz (je nach Eingangsdaten) einzutragen. Damit kann ich z.B. Temperaturänderungen von kleiner 0.2K ausfiltern, bekomme aber trotzdem kurzfristige signifikante Schwankungen mit, die mir mit der Blockzeit ggf. verloren gingen. Das ist aber natürlich sehr von den Eingangsdaten abhängig.

                                  1 Reply Last reply Reply Quote 0
                                  • B
                                    bitwicht last edited by

                                    @Marc-Berg

                                    Wenn ich ein neues Bucket anlege und den iobroker darauf umstelle, werden die measuremnts glaube automatisch neu erstellt und mit daten gefüllt.

                                    Wenn ich dann vom alten Bucket 2,3 measuremnts mit dem Befehl rüber kopiere, bleiben dann die neuen Daten erhalten? also wir das hinzugefügt ?

                                    from(bucket: "iobroker")
                                      |> range(start: -10y)
                                      |> filter(fn: (r) => r["_measurement"] == "test")
                                      |> to(bucket: "iobroker_tmp")
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • Marc Berg
                                      Marc Berg Most Active last edited by Marc Berg

                                      @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                                      Wenn ich ein neues Bucket anlege und den iobroker darauf umstelle, werden die measuremnts glaube automatisch neu erstellt und mit daten gefüllt.

                                      ja

                                      Wenn ich dann vom alten Bucket 2,3 measuremnts mit dem Befehl rüber kopiere, bleiben dann die neuen Daten erhalten? also wir das hinzugefügt ?

                                      ja, da geht nichts verloren.

                                      1 Reply Last reply Reply Quote 0
                                      • B
                                        bitwicht last edited by bitwicht

                                        @Marc-Berg

                                        Weißt du zufällig ob ich das Delete-alter eines Buckets auch nachträglich ändern kann?
                                        ZB: ich stelle es jetzt auf 1 Jahr und nach ein paar Monaten auf 6 Monate ?

                                        Oder muss ich dann das Bucket umbenennen, ein neues anlagen und die Daten rüber schieben?

                                        Sorry, habe gerade gesehen das es in den Settings einzustellen geht ....

                                        Marc Berg 1 Reply Last reply Reply Quote 0
                                        • Marc Berg
                                          Marc Berg Most Active @bitwicht last edited by

                                          @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                                          Sorry, habe gerade gesehen das es in den Settings einzustellen geht ....

                                          Genau, oder auch über die Instanzeinstellungen des Adapters.

                                          1 Reply Last reply Reply Quote 0
                                          • B
                                            bitwicht last edited by bitwicht

                                            @Marc-Berg

                                            zu dem Script, verstehe ich das richtig:

                                            import "timezone"
                                             
                                            option task = {name: "Downsampling Vb_Stromzaehler", cron: "15 0 * * *"}
                                             
                                            option location = timezone.location(name: "Europe/Berlin")
                                             
                                            data =
                                                from(bucket: "ioBroker")
                                                    |> range(start: -2mo, stop: now())
                                                    |> filter(fn: (r) => r["_measurement"] == "Vb_Stromzaehler")
                                                    |> filter(fn: (r) => r["from"] == "system.adapter.javascript.0")
                                                    // Spalten "_start", "_stop", "ack", "from", "q", ausschliessen
                                                    |> drop(columns: ["ack", "q", "from"])
                                             
                                            data
                                                |> aggregateWindow(every: 1d, fn: last, timeSrc: "_start")
                                                // In Wh ohne Komma
                                                |> toInt()
                                                |> set(key: "_measurement", value: "Hauptzaehler") 
                                                // Use the to() function to validate that the results look correct. This is optional.
                                                |> to(bucket: "Stromverbrauch", org: "RBE")
                                            

                                            Was bedeutet:
                                            name: "Downsampling Vb_Stromzaehler"
                                            Ist das frei wählbar oder ein Bucket / Measurement ?

                                            range(start: -2mo, stop: now())
                                            Wenn das Script täglich läuft müsste doch auch -1d reichen weil er doch dann regelmäßig wegschreibt oder warum macht er hier -2mo ?

                                            |> filter(fn: (r) => r["_measurement"] == "Vb_Stromzaehler")
                                            |> filter(fn: (r) => r["from"] == "system.adapter.javascript.0")
                                            er filtert nach measurement aber warum dann noch das from ?
                                            ich habe hier immer: |> filter(fn: (r) => r["_field"] == "value")

                                            |> set(key: "_measurement", value: "Hauptzaehler")
                                            |> to(bucket: "Stromverbrauch", org: "RBE")
                                            das heißt es wird in das bucket Stromverbrauch mit _measurement "Hauptzaehler" geschrieben oder ?

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            904
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            190
                                            14230
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo