Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. iobroker und telegraf [gelöst]

    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

    iobroker und telegraf [gelöst]

    This topic has been deleted. Only users with topic management privileges can see it.
    • jahnbes
      jahnbes @jahnbes last edited by jahnbes

      @jahnbes
      Es hat geklappt, das Problem
      Windows-Systemdaten -> Telegraf (Windows-PC) -> MQTT -> iobroker (Raspberry)
      ist gelöst!

      telegraf-iobroker.jpg

      Unter [1.] sind die json-Daten zu sehen, wie sie Telegraf auf dem Windows-PC sammelt und über MQTT an den iobroker schickt, hier nur die Memory-Daten.
      Unter [2.] das Testscript, mit dem der angekommene json-String im iobroker geparst und so in seine Bestandteile aufgeteilt wird.
      Unter [3.] steht das Ergebnis, die einzelnen Memory-Werte, wie sie nun im iobroker zur Verfügung stehen.

      Das weitere ist Handarbeit, die unter [3.] stehenden einzelnen Werte werden in zuvor angelegte Datenpunkte im ioboker geschrieben und stehen nun zur Verfügung, zum Beispiel zur Visualisierung.

      liv-in-sky 3 Replies Last reply Reply Quote 0
      • liv-in-sky
        liv-in-sky @jahnbes last edited by

        @jahnbes

        cool - arbeite gerade an einer version, die das einlesen und erstellen selbstständig macht - danke für den tipp mit telegraf - kannte ich nicht

        1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @jahnbes last edited by

          @jahnbes

          sieht dann so aus:

          Image 2.png

          jahnbes 1 Reply Last reply Reply Quote 0
          • jahnbes
            jahnbes @liv-in-sky last edited by jahnbes

            @liv-in-sky

            Hier der Vollständigkeit halber der Ausschnitt aus dem telegraf.conf-file, der die MQTT-Einstellungen betrifft:

            # # Configuration for MQTT server to send metrics to
             [[outputs.mqtt]]
                servers = ["192.xxx.xxx.xx:1883"] # required.
            # Bert
            #   ## MQTT outputs send metrics to this topic format
            #   ##    "<topic_prefix>/<hostname>/<pluginname>/"
            #   ##   ex: prefix/web01.example.com/mem
                topic_prefix = "Telegraf"
            #
            #   ## QoS policy for messages
            #   ##   0 = at most once
            #   ##   1 = at least once
            #   ##   2 = exactly once
                qos = 1
            #
            #   ## username and password to connect MQTT server.
            #   # username = "telegraf"
            #   # password = "metricsmetricsmetricsmetrics"
            #
            #   ## client ID, if not set a random ID is generated
            #   # client_id = ""
            #
            #   ## Timeout for write operations. default: 5s
            #   # timeout = "5s"
            #
            #   ## Optional TLS Config
            #   # tls_ca = "/etc/telegraf/ca.pem"
            #   # tls_cert = "/etc/telegraf/cert.pem"
            #   # tls_key = "/etc/telegraf/key.pem"
            #   ## Use TLS but skip chain & host verification
            #   # insecure_skip_verify = false
            #
            #   ## When true, metrics will be sent in one MQTT message per flush.  Otherwise,
            #   ## metrics are written one metric per MQTT message.
            #    batch = false
            #
            #   ## When true, metric will have RETAIN flag set, making broker cache entries until someone
            #   ## actually reads it
                retain = true
            #
            #   ## Defines the maximum length of time that the broker and client may not communicate.
            #   ## Defaults to 0 which turns the feature off. For version v2.0.12 of eclipse/mosquitto there is a
            #   ## [bug](https://github.com/eclipse/mosquitto/issues/2117) which requires keep_alive to be set.
            #   ## As a reference eclipse/paho.mqtt.golang v1.3.0 defaults to 30.
            #   # keep_alive = 0
            #
            #   ## Data format to output.
            #   ## Each data format has its own unique set of configuration options, read
            #   ## more about them here:
            #   ## https://github.com/influxdata/telegraf/blob/master/docs/DATA_FORMATS_OUTPUT.md
                data_format = "json"
            
            dnadlinger created this issue in eclipse/mosquitto

            closed No keepalive (0) still allowed with max_keepalive set #2117

            liv-in-sky 2 Replies Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @jahnbes last edited by

              @jahnbes wie gewußt 🙂 bin kein profi mit mqtt - die settings wollte ich noch bei dir fragen

              1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @jahnbes last edited by liv-in-sky

                @jahnbes

                falls es dich interessiert:

                das script (evtl muss das angeglichen werden)

                • erstellt ordner "0_userdata.0.TELEGRAF"
                • holt alles was unter "mqtt.0.telegraf.." ist
                • schreibt die werte daraus - jede minute

                let myScheduleTelegraf='* * * * * '
                
                schedule(myScheduleTelegraf,  function () {
                //iter(helper)
                $('mqtt.0.telegraf.NUC7FX.*').each(function(id, i) { 
                //log(helper.fields.MB_frei)
                let helper=JSON.parse(getState(id).val)
                //log(helper.name+"ID: "+id)
                let derName=helper.name
                let derHostname=helper.tags.host
                var keys = Object.keys(helper.fields);
                 
                 //  log(keys.toString())
                
                
                for(let u=0;u<keys.length;u++){
                  let theVal=helper.fields[keys[u]]
                  let einheit=""
                  if(keys[u].includes("ercent")  ) {theVal=Math.round(theVal);einheit="%"}
                  if(theVal>100 && derName=="mem" ) {theVal=Math.round(theVal/1024/1024/1024);einheit="GB"}
                  if(theVal>100 && derName.includes("disk") ) {theVal=Math.round(theVal/1024);einheit="GB"}
                  // log(helper.fields[keys[u]])
                   if(existsState('0_userdata.0.TELEGRAF.'+derHostname+'.'+derName+'.'+keys[u])) setState('0_userdata.0.TELEGRAF.'+derHostname+'.'+derName+'.'+keys[u],theVal);
                        else createState('0_userdata.0.TELEGRAF.'+derHostname+'.'+derName+'.'+keys[u], theVal, { name: derHostname+'-'+keys[u],unit: einheit}); // type: "mixed"
                }
                
                
                });
                
                });
                

                meine konfig für die festplatten (für jede festplatte ein eintrag, eintrag in Messurement erzeugt den dp):

                   [[inputs.win_perf_counters.object]]
                    #  Disk times and queues
                     ObjectName = "LogicalDisk"
                     Instances = ["E:"]
                     Counters = [
                       "% Idle Time",
                       "% Free Space",
                       "Free Megabytes",
                     ]
                     Measurement = "win_disk-E"	
                
                jahnbes 1 Reply Last reply Reply Quote 1
                • jahnbes
                  jahnbes @liv-in-sky last edited by jahnbes

                  @liv-in-sky

                  Danke für den Tipp mit den Platten, der hat mir sehr geholfen, die erste ist schon drin.

                  Weißt Du, was unter "cpu" die Felder "usage_idle" und insbesondere "usage_system" und "usage_user" bedeuten?

                  Viele Grüße, Bert.

                  liv-in-sky 2 Replies Last reply Reply Quote 0
                  • liv-in-sky
                    liv-in-sky @jahnbes last edited by

                    @jahnbes

                    schau mal da:

                    https://bobcares.com/blog/perfmon-counters-for-cpu-usage/

                    1 Reply Last reply Reply Quote 0
                    • liv-in-sky
                      liv-in-sky @jahnbes last edited by

                      @jahnbes

                      in deutsch habe ich nur das gefunden

                      Prozessorauslastung messen und Vorlage speichern
                      Um die Auslastung des Prozessors zu messen, wird am besten der Menüpunkt „Performance Monitor“ aufgerufen. Mit „Blank workspace“ wird ein neuer Workspace zur Überwachung erstellt. Danach wird mit „Add Counter“ das Objekt „Prozessor“ ausgewählt, als „Instance“ wählt man idealerweise alle Prozessoren im System. Hier kann auch nach einzelnen Kernen gefiltert werden. Als „Counter“ wird „Prozessorzeit“ aktiviert.

                      Es sollte darauf geachtet werden, dass die Auslastung des Prozessors auf verschiedene Prozesse verteilt wird. Bei „Graphy Type“ kann zwischen grafischer Ansicht und einer Tabelle unterschieden werden. Der Prozessor sollte nur maximal bis 70% ausgelastet werden, idealerweise deutlich darunter.

                      Parallel lassen sich weitere Counter hinzufügen, zum Beispiel „Priviligerte Zeit (%)“. Hier wird die Gesamtzeit in Prozenten angezeigt, die der Prozessor benötigt, um Windows-Kernel-Befehle auszuführen. Auch hier sollten die Werte nicht zu hoch liegen.

                      Ebenfalls wichtig ist noch „Prozessor: Benutzerzeit (%)“. Dieser Wert gibt den prozentualen Zeitanteil an der Gesamtzeit an, die der Prozessor benötigt, um Benutzerprozesse auszuführen. Dabei kann es sich zum Beispiel um Prozesse für Microsoft SQL-Server handeln.

                      Über „System: Prozessor-Warteschlangenlänge“, beziehungsweise „Processor Queue Length“ lassen sich die Threads messen, die auf Prozessorzeit warten. Wenn die Threads eines Prozesses mehr Zyklen benötigen als zur Verfügung stehen, kann es zu Problemen kommen. Wenn bei dieser Messung viele Prozesse versuchen, Prozessorzeit zu beanspruchen, sollten schnellere Prozessoren verbaut werden.

                      jahnbes 1 Reply Last reply Reply Quote 0
                      • jahnbes
                        jahnbes @liv-in-sky last edited by jahnbes

                        @liv-in-sky

                        Nun ist es geschafft, die Systemdaten des Windows-PC werden auf diesem mittels Telegraf gesammelt und mit MQTT an den iobroker gesandt, der auf einem Raspberry Pi läuft.
                        Von dort aus erfolgt u.a. die Visualisierung mit HABpanel:

                        dashboard_PC.jpg

                        Die Daten der Netzwerkplatte, ein Synology-NAS, kommen über den Adapter "Synology NAS" in den iobroker.

                        Die Temperaturen im PC würde ich auch gern darstellen, da bin ich aber auch mit Telegraf noch nicht rangekommen.

                        liv-in-sky 3 Replies Last reply Reply Quote 1
                        • liv-in-sky
                          liv-in-sky @jahnbes last edited by

                          @jahnbes die temp sache check ich auch nicht

                          mache das so (etwas umständlich):

                          https://forum.iobroker.net/topic/27520/cpu-temperatur-win-pc-in-iobroker-darstellen

                          1 Reply Last reply Reply Quote 0
                          • liv-in-sky
                            liv-in-sky @jahnbes last edited by

                            @jahnbes

                            bin etwas weiter mit temp in telegraf

                            Image 4.png

                            Image 5.png

                            1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @jahnbes last edited by

                              @jahnbes

                              das hier downloaden und laufen lassen - als service oder beim startup - zum testen einfach aufrufen

                              https://openhardwaremonitor.org/

                              das in conf:

                              
                               
                              [[inputs.exec]]
                                 interval = "30s"
                                 commands = ['powershell -executionpolicy bypass -File "C:/Program Files/telegraf/ohm.ps1"']
                                 #data_format = "influx"
                              

                              das hier in den ordner, wo telegraf läuft - muss als file dort liegen:

                              ohm.ps1

                              im mqtt setting auf influx umstellen !

                              data_format = "influx"
                              
                              
                              

                              das hier enablen - darunter steht nix - nur diese zeile - ist die temp des motherboards

                              [[inputs.temp]]
                              
                              1 Reply Last reply Reply Quote 0
                              • liv-in-sky
                                liv-in-sky @jahnbes last edited by

                                @jahnbes

                                falls du mit meinem script arbeitest: - alle dp löschen und dieses script starten

                                update

                                let myScheduleTelegraf='*/30 * * * * * '
                                
                                schedule(myScheduleTelegraf,  function () {
                                //iter(helper)
                                $('mqtt.0.telegraf.*.*').each(function(id, i) { 
                                //log(helper.fields.MB_frei)
                                let helper=JSON.parse(getState(id).val)
                                //log(helper.name+"ID: "+id)
                                let derName=helper.name
                                let derHostname=helper.tags.host
                                var keys = Object.keys(helper.fields);
                                 
                                 //  log(keys.toString())
                                
                                
                                for(let u=0;u<keys.length;u++){
                                  let theVal=helper.fields[keys[u]]
                                  let einheit=""
                                  if(keys[u].includes("ercent")  ) {theVal=Math.round(theVal);einheit="%"}
                                  if(theVal>100 && derName=="mem" ) {theVal=Math.round(theVal/1024/1024/1024);einheit="GB"}
                                  if(theVal>100 && derName.includes("disk") ) {theVal=Math.round(theVal/1024);einheit="GB"}
                                   if(theVal<=100 && derName.includes("temp") ) {einheit="°C"}
                                  //log(helper.fields[keys[u]])
                                   if(existsState('0_userdata.0.TELEGRAF.'+derHostname+'.'+derName+'.'+keys[u])) setState('0_userdata.0.TELEGRAF.'+derHostname+'.'+derName+'.'+keys[u],theVal);
                                        else createState('0_userdata.0.TELEGRAF.'+derHostname+'.'+derName+'.'+keys[u], theVal, { name: derHostname+'-'+keys[u],unit: einheit}); // type: "mixed"
                                }
                                
                                
                                });
                                
                                });
                                

                                jahnbes 1 Reply Last reply Reply Quote 0
                                • jahnbes
                                  jahnbes @liv-in-sky last edited by

                                  @liv-in-sky

                                  Ich habe es mir angesehen und eine Frage. Du setzt an einer Stelle

                                  data_format = "influx"
                                  

                                  Für meine Anwendung muss ich aber

                                  data_format = "json"
                                  

                                  setzen. Beißt sich das nicht, oder habe ich etwas falsch verstanden?

                                  Gruß Bert.

                                  liv-in-sky 1 Reply Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky @jahnbes last edited by liv-in-sky

                                    @jahnbes ist verwirrend

                                    aber anders geht es nicht - sonst funkt. der hardware manager nicht - bzw die daten

                                    bei mir kommt trotzdem alles richtig an -
                                    Image 2.png

                                    1 Reply Last reply Reply Quote 0
                                    • liv-in-sky
                                      liv-in-sky @jahnbes last edited by

                                      @jahnbes nee - warte nochmal - überprüfe gerade

                                      1 Reply Last reply Reply Quote 0
                                      • liv-in-sky
                                        liv-in-sky @jahnbes last edited by

                                        @jahnbes

                                        bei mqtt setting - ist json
                                        bei dem

                                        [[inputs.exec]]
                                        
                                           interval = "30s"
                                        
                                           commands = ['powershell -executionpolicy bypass -File "C:/Program Files/telegraf/ohm.ps1"']
                                        
                                           #data_format = "influx"
                                        

                                        ist das dataformat auskommentiert

                                        jahnbes 1 Reply Last reply Reply Quote 0
                                        • jahnbes
                                          jahnbes @liv-in-sky last edited by

                                          @liv-in-sky

                                          Ok, ich hatte gepennt. Danke!

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

                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          497
                                          Online

                                          31.9k
                                          Users

                                          80.1k
                                          Topics

                                          1.3m
                                          Posts

                                          2
                                          24
                                          2502
                                          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