Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. Test Adapter Pylontech v0.0.10

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.5k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.0k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    2.7k

Test Adapter Pylontech v0.0.10

Geplant Angeheftet Gesperrt Verschoben Tester
210 Beiträge 29 Kommentatoren 39.5k Aufrufe 24 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • B bios123

    @PLCHome-0 Da passt was nicht. Hab gestern Abend mal die v0.0.8 angeschmissen und die Zellspannungen loggen lassen. Das scheint auch teilweise zu funktionieren. Seit heute Morgen dann anhaltende Fehler. Abrufintervall steht auf 5 Minuten:

    2024-02-19 00:28:50.237  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 00:48:50.021  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 02:58:50.275  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 06:03:49.663  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 06:08:49.662  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 06:13:49.662  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 09:13:50.506  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 10:33:49.690  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 10:38:49.691  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 10:43:49.693  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 10:48:49.692  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 10:53:49.980  - error: pylontech.0 (58315) Error: timeout
    2024-02-19 10:55:31.819  - error: pylontech.0 (64010) Error: timeout
    2024-02-19 11:00:31.817  - error: pylontech.0 (64010) Error: timeout
    2024-02-19 11:05:31.816  - error: pylontech.0 (64010) Error: timeout
    2024-02-19 11:06:49.941  - error: pylontech.0 (64150) TypeError: Cannot read properties of undefined (reading 'battery01')
    2024-02-19 11:07:21.962  - error: pylontech.0 (64171) TypeError: Cannot read properties of undefined (reading 'battery01')
    2024-02-19 11:08:19.560  - error: host.iobroker Invalid request getRepository. "callback" or "from" is null
    2024-02-19 11:09:46.013  - error: pylontech.0 (64209) TypeError: Cannot read properties of undefined (reading 'battery01')
    2024-02-19 11:11:48.955  - error: pylontech.0 (64245) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:12:14.254  - error: pylontech.0 (64265) Error: timeout
    2024-02-19 11:17:14.255  - error: pylontech.0 (64265) Error: timeout
    2024-02-19 11:22:09.590  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:27:09.588  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:32:09.585  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:37:09.589  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:42:09.586  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:47:09.584  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:52:09.589  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 11:57:09.335  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 12:02:09.333  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 12:07:09.336  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    2024-02-19 12:12:09.337  - error: pylontech.0 (64265) TypeError: Cannot read properties of undefined (reading 'power')
    
    PLCHome 0P Offline
    PLCHome 0P Offline
    PLCHome 0
    Developer
    schrieb am zuletzt editiert von
    #113

    @bios123
    Danke fürs Testen.
    Ich bin ein wenig verwundet, dass es bei dir nicht geht. Hast du US-Modell ausgewählt? Wie verbindest du den seriellen Port mit dem Rechner?

    In der Emulation läuft er bei mir. stat <batt> kann man nicht auf dem Akku abfragen wie bei den Pylontechs. Das passt aber nicht zu den Fehlermeldungen. soh <batt> sieht auch komisch aus.

    
    
    PYTES>
    
    PYTES>stat 1
    
    @
    
    Invalid command or fail to excute.
    
    Usage:
    Statistic data show - stat
    
    $$
    
    
    PYTES>
    
    PYTES>soh 1
    
    @
    
    Power   1
    
    Battery    Voltage    SOHStatus  È$        
    
    0          3327       00000000
    
    1          3327       00000000
    
    2          3328       00000000
    
    3          3328       00000000
    
    4          3328       00000000
    
    5          3328       00000000
    
    6          3328       00000000
    
    7          3328       00000000
    
    8          3328       00000000
    
    9          3328       00000000
    
    10         3328       00000000
    
    11         3328       00000000
    
    12         3328       00000000
    
    13         3328       00000000
    
    14         3328       00000000
    
    15         3326       00000000
    
    Command completed successfully
    
    $$
    
    PYTES> 
    

    Am besten löscht du auch einmal alle Objekte in der Version 0.0.7 hat der da mist angelegt.
    Und schalte doch mal die beiden Abrufe ab.

    145dc461-eceb-4ba7-be95-4fbb7551c4d5-image.png

    1 Antwort Letzte Antwort
    0
    • B Offline
      B Offline
      bios123
      schrieb am zuletzt editiert von bios123
      #114

      @PLCHome-0 die alten Objekte hatte ich bereits gelöscht um sicher zu gehen das alles sauber angelegt wird. SOH und STAT hab ich wie beschrieben ausgeschaltet. Das hilft aber nicht wirklich. Der Adapter ruft die Daten mal ab und mal nicht. Ich habe versucht den blockierenden Punkt zu finden. Das Kommando 'pwr' wird geschickt und ein Antwort gibt es auch, danach dann wieder Error: timeout. Ich vermute 'pwr' kann ich mit 'Batteriestromdaten herunterladen' abschalten? Wie schnell rufst du die Daten ab? Eventuell braucht die Pytes V5 nach jeder Anfrage einen Moment. Ich kann das zumindest nicht nachstellen, wenn ich manuell hintereinader ein Request abschicke. Ich rufe übrigens direkt per /dev/ttyUSB0 ab, Interface hängt am iobroker und 'US series' ist ausgewählt.

      
      pylontech.0
      2024-02-21 11:19:04.886	error	Error: timeout
      
      pylontech.0
      2024-02-21 11:18:59.932	silly	if
      
      pylontech.0
      2024-02-21 11:18:59.884	silly	16 - - - - - - - Absent - - - - - - - - - Command completed successfully $$ PYTES>
      
      pylontech.0
      2024-02-21 11:18:59.852	silly	- - Absent - - - - - - - - - 14 - - - - - - - Absent - - - - - - - - - 15 - - - - - - - Absent - - - - - - - - -
      
      pylontech.0
      2024-02-21 11:18:59.810	silly	- - - - - - 11 - - - - - - - Absent - - - - - - - - - 12 - - - - - - - Absent - - - - - - - - - 13 - - - - -
      
      pylontech.0
      2024-02-21 11:18:59.766	silly	- 8 - - - - - - - Absent - - - - - - - - - 9 - - - - - - - Absent - - - - - - - - - 10 - - - - - - - Absent - - -
      
      pylontech.0
      2024-02-21 11:18:59.723	silly	- - - - - - Absent - - - - - - - - - 6 - - - - - - - Absent - - - - - - - - - 7 - - - - - - - Absent - - - - - - - -
      
      pylontech.0
      2024-02-21 11:18:59.680	silly	- - - - - - - - 3 - - - - - - - Absent - - - - - - - - - 4 - - - - - - - Absent - - - - - - - - - 5 -
      
      pylontech.0
      2024-02-21 11:18:59.397	silly	PYTES> PYTES>pwr @ Power Volt Curr Tempr Tlow Thigh Vlow Vhigh Base.St Volt.St Curr.St Temp.St Coulomb Time B.V.St B.T.St Barcode DevType 1 53708 2164 24000 19000 19000 3352 3359 Charge Normal Normal Normal 52% 2024-02-21 18:15:57 Normal Normal ES1000XXXP010XXX E-BOX-48100V-D 2 - - - - - - - Absent -
      

      Gruß Markus

      PLCHome 0P 1 Antwort Letzte Antwort
      0
      • PLCHome 0P Offline
        PLCHome 0P Offline
        PLCHome 0
        Developer
        schrieb am zuletzt editiert von PLCHome 0
        #115

        @bios123 sagte in Test Adapter Pylontech v0.0.8:

        Noch mal danke für deine Geduld und das Interesse, den Adapter zu verbessern.
        Aber ich muss gerade sagen, so richtig Plan habe ich nicht, warum es nicht gehen soll.
        USB Adapter ist schon mal gut, wobei ein Kollege damit auch schon Probleme hatte.

        Meines Wissen nach hatte er aber auch Fehlermeldungen im

        sudo dmesg | grep usb
        

        Der Adapter ruft die Daten mal ab und mal nicht.

        Komisch

        Ich vermute 'pwr' kann ich mit 'Batteriestromdaten herunterladen' abschalten?

        Download the battery power data
        The "pwr" command is always written to the console. The command “pwr -n-” is only written to the console if this is set here. Here you will find information about the positions of the individual batteries. It is needed for the object tree. If this is switched off, the information from the "pwr" command is not transferred to the ioBroker and the "pwr -n-" command is not issued.

        ja also pwr und pwr<n> alle weiten abrufe mit <n> sind dann auch nicht mehr möglich.

        Wie schnell rufst du die Daten ab?

        Der Adapter hat eine Que, wenn auf einen Befehl eine Antwort kommt, wird der nächste abgearbeitet. Da eine Pause zum Testen einzubauen ist möglich.
        Vielleicht sollten wir zuerst einmal versuchen, das Time-out zu erhöhen.
        Da der Adapter in Typescript geschrieben ist, sind die JS Dateien etwas unübersichtlich, da sie generiert wurden.

        Ach, das Intervall kannst du zum Test auch besser mal auf 2, 3 oder 5 Minuten stellen.

        unter build/pylontech/WorkerAbstarkt.js findest du in Zeile 42:

        this._timeout = 5e3;
        

        das sind 5000ms oder 5sec. Trag doch da einmal 10000 (10e3) oder 20000 (20e3) ein.

        Vielleicht denkt der Accu zu lange :-)

        Bei dem Pylontech muss der Befehl mit einem \r abgeschlossen werden, vielleicht mag er auch das nicht. Du kannst in Zeile 72-mal versuchen, ob es mit \r\n besser geht.

        this.sendData(this._activeCmd.cmd + "\r");
        

        oder am Anfang einen Umbruch um den letzten Befehl anzuschließen..

        this.sendData("\r\n" + this._activeCmd.cmd + "\r");
        

        oder \r muss gegen \n getauscht werden.

        \r ist Wagenrücklauf \n ist Zeilenvorschub. Unter Linux wird auf der shell ein \n gesendet. Der Pylontech hat gerne ein \r.

        B 1 Antwort Letzte Antwort
        0
        • PLCHome 0P PLCHome 0

          @bios123 sagte in Test Adapter Pylontech v0.0.8:

          Noch mal danke für deine Geduld und das Interesse, den Adapter zu verbessern.
          Aber ich muss gerade sagen, so richtig Plan habe ich nicht, warum es nicht gehen soll.
          USB Adapter ist schon mal gut, wobei ein Kollege damit auch schon Probleme hatte.

          Meines Wissen nach hatte er aber auch Fehlermeldungen im

          sudo dmesg | grep usb
          

          Der Adapter ruft die Daten mal ab und mal nicht.

          Komisch

          Ich vermute 'pwr' kann ich mit 'Batteriestromdaten herunterladen' abschalten?

          Download the battery power data
          The "pwr" command is always written to the console. The command “pwr -n-” is only written to the console if this is set here. Here you will find information about the positions of the individual batteries. It is needed for the object tree. If this is switched off, the information from the "pwr" command is not transferred to the ioBroker and the "pwr -n-" command is not issued.

          ja also pwr und pwr<n> alle weiten abrufe mit <n> sind dann auch nicht mehr möglich.

          Wie schnell rufst du die Daten ab?

          Der Adapter hat eine Que, wenn auf einen Befehl eine Antwort kommt, wird der nächste abgearbeitet. Da eine Pause zum Testen einzubauen ist möglich.
          Vielleicht sollten wir zuerst einmal versuchen, das Time-out zu erhöhen.
          Da der Adapter in Typescript geschrieben ist, sind die JS Dateien etwas unübersichtlich, da sie generiert wurden.

          Ach, das Intervall kannst du zum Test auch besser mal auf 2, 3 oder 5 Minuten stellen.

          unter build/pylontech/WorkerAbstarkt.js findest du in Zeile 42:

          this._timeout = 5e3;
          

          das sind 5000ms oder 5sec. Trag doch da einmal 10000 (10e3) oder 20000 (20e3) ein.

          Vielleicht denkt der Accu zu lange :-)

          Bei dem Pylontech muss der Befehl mit einem \r abgeschlossen werden, vielleicht mag er auch das nicht. Du kannst in Zeile 72-mal versuchen, ob es mit \r\n besser geht.

          this.sendData(this._activeCmd.cmd + "\r");
          

          oder am Anfang einen Umbruch um den letzten Befehl anzuschließen..

          this.sendData("\r\n" + this._activeCmd.cmd + "\r");
          

          oder \r muss gegen \n getauscht werden.

          \r ist Wagenrücklauf \n ist Zeilenvorschub. Unter Linux wird auf der shell ein \n gesendet. Der Pylontech hat gerne ein \r.

          B Offline
          B Offline
          bios123
          schrieb am zuletzt editiert von
          #116

          @plchome-0 habe gerade nochmal ins log geschaut:

          
          pylontech.0
          2024-02-21 12:42:30.168	silly	bat 1 @ Battery Volt Tempr Base State Volt. State Curr. State Temp. State Coulomb 0 3361 19000 Charge Normal Normal Normal 60% 60896 mAH 1 3360 19000 Charge Normal Normal Normal 60% 60446 mAH 2 3362 19000 Charge Normal Normal Normal 60% 60841 mAH 3 3361 19000 Charge Normal Normal Normal 60%
          
          pylontech.0
          2024-02-21 12:42:30.124	silly	PYTES>i1 @ Unknown command 'i1' - try 'help' $$ PYTES>
          
          pylontech.0
          2024-02-21 12:42:30.092	silly	- - Absent - - - - - - - - - Command completed successfully $$
          
          pylontech.0
          2024-02-21 12:42:30.065	silly	- - - - - - 14 - - - - - - - Absent - - - - - - - - - 15 - - - - - - - Absent - - - - - - - - - 16 - - - - -
          
          pylontech.0
          2024-02-21 12:42:30.022	silly	- 11 - - - - - - - Absent - - - - - - - - - 12 - - - - - - - Absent - - - - - - - - - 13 - - - - - - - Absent - - -
          
          pylontech.0
          2024-02-21 12:42:29.979	silly	- - - - - - Absent - - - - - - - - - 9 - - - - - - - Absent - - - - - - - - - 10 - - - - - - - Absent - - - - - - - -
          
          pylontech.0
          2024-02-21 12:42:29.936	silly	- - - - - - - - 6 - - - - - - - Absent - - - - - - - - - 7 - - - - - - - Absent - - - - - - - - - 8 -
          
          pylontech.0
          2024-02-21 12:42:29.893	silly	- - - - 3 - - - - - - - Absent - - - - - - - - - 4 - - - - - - - Absent - - - - - - - - - 5 - - - - - - - Absent -
          
          pylontech.0
          2024-02-21 12:42:29.850	silly	S>pwr @ Power Volt Curr Tempr Tlow Thigh Vlow Vhigh Base.St Volt.St Curr.St Temp.St Coulomb Time B.V.St B.T.St Barcode DevType 1 53780 529 24000 19000 19000 3359 3363 Charge Normal Normal Normal 60% 2024-02-21 19:39:27 Normal Normal ES1000626P010443 E-BOX-48100V-D 2 - - - - - - - Absent - - - - -
          
          pylontech.0
          2024-02-21 12:42:29.807	silly	@ Unknown command 'i' - try 'help' $$ PYTES> PYTE
          
          pylontech.0
          2024-02-21 12:36:35.083	error	Error: timeout
          
          pylontech.0
          2024-02-21 12:36:30.112	silly	PYTES>i
          
          pylontech.0
          2024-02-21 12:36:30.080	silly	- - - - Absent - - - - - - - - - Command completed successfully $$
          
          pylontech.0
          2024-02-21 12:36:30.048	silly	- - - - - - - 14 - - - - - - - Absent - - - - - - - - - 15 - - - - - - - Absent - - - - - - - - - 16 - - -
          
          pylontech.0
          2024-02-21 12:36:30.005	silly	- - - 11 - - - - - - - Absent - - - - - - - - - 12 - - - - - - - Absent - - - - - - - - - 13 - - - - - - - Absent - -
          
          pylontech.0
          2024-02-21 12:36:29.962	silly	8 - - - - - - - Absent - - - - - - - - - 9 - - - - - - - Absent - - - - - - - - - 10 - - - - - - - Absent - - - - - -
          
          pylontech.0
          2024-02-21 12:36:29.919	silly	Absent - - - - - - - - - 6 - - - - - - - Absent - - - - - - - - - 7 - - - - - - - Absent - - - - - - - - -
          
          pylontech.0
          2024-02-21 12:36:29.876	silly	- - - - 3 - - - - - - - Absent - - - - - - - - - 4 - - - - - - - Absent - - - - - - - - - 5 - - - - - - -
          
          pylontech.0
          2024-02-21 12:36:29.833	silly	PYTES> PYTES>pwr @ Power Volt Curr Tempr Tlow Thigh Vlow Vhigh Base.St Volt.St Curr.St Temp.St Coulomb Time B.V.St B.T.St Barcode DevType 1 53903 3338 24000 19000 19000 3367 3371 Charge Normal Normal Normal 60% 2024-02-21 19:33:27 Normal Normal ES1000626P010443 E-BOX-48100V-D 2 - - - - - - - Absent - - - - -
          

          den Aufruf 'i' bzw 'i1' gibt es nicht, wo kommt der her?

          Heute Abend hab ich sicher mehr Zeit...

          PLCHome 0P 1 Antwort Letzte Antwort
          0
          • B bios123

            @plchome-0 habe gerade nochmal ins log geschaut:

            
            pylontech.0
            2024-02-21 12:42:30.168	silly	bat 1 @ Battery Volt Tempr Base State Volt. State Curr. State Temp. State Coulomb 0 3361 19000 Charge Normal Normal Normal 60% 60896 mAH 1 3360 19000 Charge Normal Normal Normal 60% 60446 mAH 2 3362 19000 Charge Normal Normal Normal 60% 60841 mAH 3 3361 19000 Charge Normal Normal Normal 60%
            
            pylontech.0
            2024-02-21 12:42:30.124	silly	PYTES>i1 @ Unknown command 'i1' - try 'help' $$ PYTES>
            
            pylontech.0
            2024-02-21 12:42:30.092	silly	- - Absent - - - - - - - - - Command completed successfully $$
            
            pylontech.0
            2024-02-21 12:42:30.065	silly	- - - - - - 14 - - - - - - - Absent - - - - - - - - - 15 - - - - - - - Absent - - - - - - - - - 16 - - - - -
            
            pylontech.0
            2024-02-21 12:42:30.022	silly	- 11 - - - - - - - Absent - - - - - - - - - 12 - - - - - - - Absent - - - - - - - - - 13 - - - - - - - Absent - - -
            
            pylontech.0
            2024-02-21 12:42:29.979	silly	- - - - - - Absent - - - - - - - - - 9 - - - - - - - Absent - - - - - - - - - 10 - - - - - - - Absent - - - - - - - -
            
            pylontech.0
            2024-02-21 12:42:29.936	silly	- - - - - - - - 6 - - - - - - - Absent - - - - - - - - - 7 - - - - - - - Absent - - - - - - - - - 8 -
            
            pylontech.0
            2024-02-21 12:42:29.893	silly	- - - - 3 - - - - - - - Absent - - - - - - - - - 4 - - - - - - - Absent - - - - - - - - - 5 - - - - - - - Absent -
            
            pylontech.0
            2024-02-21 12:42:29.850	silly	S>pwr @ Power Volt Curr Tempr Tlow Thigh Vlow Vhigh Base.St Volt.St Curr.St Temp.St Coulomb Time B.V.St B.T.St Barcode DevType 1 53780 529 24000 19000 19000 3359 3363 Charge Normal Normal Normal 60% 2024-02-21 19:39:27 Normal Normal ES1000626P010443 E-BOX-48100V-D 2 - - - - - - - Absent - - - - -
            
            pylontech.0
            2024-02-21 12:42:29.807	silly	@ Unknown command 'i' - try 'help' $$ PYTES> PYTE
            
            pylontech.0
            2024-02-21 12:36:35.083	error	Error: timeout
            
            pylontech.0
            2024-02-21 12:36:30.112	silly	PYTES>i
            
            pylontech.0
            2024-02-21 12:36:30.080	silly	- - - - Absent - - - - - - - - - Command completed successfully $$
            
            pylontech.0
            2024-02-21 12:36:30.048	silly	- - - - - - - 14 - - - - - - - Absent - - - - - - - - - 15 - - - - - - - Absent - - - - - - - - - 16 - - -
            
            pylontech.0
            2024-02-21 12:36:30.005	silly	- - - 11 - - - - - - - Absent - - - - - - - - - 12 - - - - - - - Absent - - - - - - - - - 13 - - - - - - - Absent - -
            
            pylontech.0
            2024-02-21 12:36:29.962	silly	8 - - - - - - - Absent - - - - - - - - - 9 - - - - - - - Absent - - - - - - - - - 10 - - - - - - - Absent - - - - - -
            
            pylontech.0
            2024-02-21 12:36:29.919	silly	Absent - - - - - - - - - 6 - - - - - - - Absent - - - - - - - - - 7 - - - - - - - Absent - - - - - - - - -
            
            pylontech.0
            2024-02-21 12:36:29.876	silly	- - - - 3 - - - - - - - Absent - - - - - - - - - 4 - - - - - - - Absent - - - - - - - - - 5 - - - - - - -
            
            pylontech.0
            2024-02-21 12:36:29.833	silly	PYTES> PYTES>pwr @ Power Volt Curr Tempr Tlow Thigh Vlow Vhigh Base.St Volt.St Curr.St Temp.St Coulomb Time B.V.St B.T.St Barcode DevType 1 53903 3338 24000 19000 19000 3367 3371 Charge Normal Normal Normal 60% 2024-02-21 19:33:27 Normal Normal ES1000626P010443 E-BOX-48100V-D 2 - - - - - - - Absent - - - - -
            

            den Aufruf 'i' bzw 'i1' gibt es nicht, wo kommt der her?

            Heute Abend hab ich sicher mehr Zeit...

            PLCHome 0P Offline
            PLCHome 0P Offline
            PLCHome 0
            Developer
            schrieb am zuletzt editiert von
            #117

            @bios123

            Da gibts nur das i von Info und die Nummer von den anderen Befehl. Das sieht mir aber nach eier Schnittstelle aus, die zeitweise abkackt oder NodeJs mach blödsinn :-(

            protected _getDataUS(option: any): Promise<any> {
              return new Promise<any>((resolve, reject) => {
                this._getUsPwr()
                  .then((p: { pwrs: any; batteries: string[] }) => {
                    this._getUsInfo(p, option.info, option.power)
                      .then((p: resultForGet) => {
                        this._getUsNormal(p, PWR, POWER, option.power)
                          .then(p => {
                            this._getUsNormal(p, STAT, STATISTIC, option.statistic)
                              .then(p => {
                                this._getUsBatterie(p, BAT, option.celldata)
                                  .then(p => {
                                    this._getUsBatterie(p, SOH, option.cellsoh)
                                      .then(p => {
                                        this._getOne(p.allData, LOG, LOG, option.log)
                                          .then(allData => {
                                            this._getOne(allData, TIME, TIME, option.time)
                                              .then(allData => {
                                                resolve(allData);
                                              })
                                              .catch(reject);
                                          })
                                          .catch(reject);
                                      })
                                      .catch(reject);
                                  })
                                  .catch(reject);
                              })
                              .catch(reject);
                          })
                          .catch(reject);
                      })
                      .catch(reject);
                  })
                  .catch(reject);
              });
            }
            
            B 1 Antwort Letzte Antwort
            0
            • PLCHome 0P PLCHome 0

              @bios123

              Da gibts nur das i von Info und die Nummer von den anderen Befehl. Das sieht mir aber nach eier Schnittstelle aus, die zeitweise abkackt oder NodeJs mach blödsinn :-(

              protected _getDataUS(option: any): Promise<any> {
                return new Promise<any>((resolve, reject) => {
                  this._getUsPwr()
                    .then((p: { pwrs: any; batteries: string[] }) => {
                      this._getUsInfo(p, option.info, option.power)
                        .then((p: resultForGet) => {
                          this._getUsNormal(p, PWR, POWER, option.power)
                            .then(p => {
                              this._getUsNormal(p, STAT, STATISTIC, option.statistic)
                                .then(p => {
                                  this._getUsBatterie(p, BAT, option.celldata)
                                    .then(p => {
                                      this._getUsBatterie(p, SOH, option.cellsoh)
                                        .then(p => {
                                          this._getOne(p.allData, LOG, LOG, option.log)
                                            .then(allData => {
                                              this._getOne(allData, TIME, TIME, option.time)
                                                .then(allData => {
                                                  resolve(allData);
                                                })
                                                .catch(reject);
                                            })
                                            .catch(reject);
                                        })
                                        .catch(reject);
                                    })
                                    .catch(reject);
                                })
                                .catch(reject);
                            })
                            .catch(reject);
                        })
                        .catch(reject);
                    })
                    .catch(reject);
                });
              }
              
              B Offline
              B Offline
              bios123
              schrieb am zuletzt editiert von
              #118

              @plchome-0 Das fruchtet leider alles nicht. Zeit erhöhen macht keinen Unterschied und Zeilenabschluss mit \r und/oder \n in vielen Kombination, bringt auch keine Besserung. Hatte neben dem FTDI Adapter (vergossen mit Consolenanschluss auf RJ45) auch einen alten PL2303 versucht. Der scheint aber nicht wirklich gut zu laufen. Würde den USB/Serial Adapter gerne ausschließen, kannst du mir sagen welcher Adapter (vorzugweise über Amazon zu bekommen) gut funktioniert? Hab zwar noch ESP32/ESP8266 da, aber keine MAX Pegelwandler mehr.

              Wie gesagt teilweise klappt die Abfrage mehrfach hintereinander und dann wieder timeout. Vielleicht ist die serielle Schnitstelle von der Pytes-V5 einfach eine Diva.

              PLCHome 0P 2 Antworten Letzte Antwort
              0
              • B bios123

                @plchome-0 Das fruchtet leider alles nicht. Zeit erhöhen macht keinen Unterschied und Zeilenabschluss mit \r und/oder \n in vielen Kombination, bringt auch keine Besserung. Hatte neben dem FTDI Adapter (vergossen mit Consolenanschluss auf RJ45) auch einen alten PL2303 versucht. Der scheint aber nicht wirklich gut zu laufen. Würde den USB/Serial Adapter gerne ausschließen, kannst du mir sagen welcher Adapter (vorzugweise über Amazon zu bekommen) gut funktioniert? Hab zwar noch ESP32/ESP8266 da, aber keine MAX Pegelwandler mehr.

                Wie gesagt teilweise klappt die Abfrage mehrfach hintereinander und dann wieder timeout. Vielleicht ist die serielle Schnitstelle von der Pytes-V5 einfach eine Diva.

                PLCHome 0P Offline
                PLCHome 0P Offline
                PLCHome 0
                Developer
                schrieb am zuletzt editiert von PLCHome 0
                #119

                @bios123 Ich hab gerade den LogiLink AU0034 aus der Readme im einasatz, weil mir bei dem ESP die USB-Buchse zur Spannungsversorgung abgerissen ist und ich noch keine Zeit (oder Bock) hatte, den wieder zu reparieren :-(

                Ich habe aber auch keinen PI, sondern einen NUC im Einsatz. Ich gehe mal von einem PI als Hardware aus.

                Zuerst solltest du mal im dmesg schauen, ob die Schnittstelle Fehler meldet, wenn da irgendwas nicht stimmt, dann sieht man es da.

                Komisch ist ja, das es mit den Testscripts funktioniert und im Adapter Fehler produziert.
                In der Debugausgabe, die Du gepostet hast, überholen sich auch die Meldungen. Das kann aber auch wegen Multitasking normal sein.

                1 Antwort Letzte Antwort
                0
                • B bios123

                  @plchome-0 Das fruchtet leider alles nicht. Zeit erhöhen macht keinen Unterschied und Zeilenabschluss mit \r und/oder \n in vielen Kombination, bringt auch keine Besserung. Hatte neben dem FTDI Adapter (vergossen mit Consolenanschluss auf RJ45) auch einen alten PL2303 versucht. Der scheint aber nicht wirklich gut zu laufen. Würde den USB/Serial Adapter gerne ausschließen, kannst du mir sagen welcher Adapter (vorzugweise über Amazon zu bekommen) gut funktioniert? Hab zwar noch ESP32/ESP8266 da, aber keine MAX Pegelwandler mehr.

                  Wie gesagt teilweise klappt die Abfrage mehrfach hintereinander und dann wieder timeout. Vielleicht ist die serielle Schnitstelle von der Pytes-V5 einfach eine Diva.

                  PLCHome 0P Offline
                  PLCHome 0P Offline
                  PLCHome 0
                  Developer
                  schrieb am zuletzt editiert von
                  #120

                  @bios123 Du hast aber auch die Masse verbunden? Das fehlte mal eine Zeit in den Anleitungen.

                  DSUB signal
                  2 RxD
                  3 TxD
                  5 Ground

                  Andere Seite in deinem Handbuch

                  1 Antwort Letzte Antwort
                  0
                  • B Offline
                    B Offline
                    bios123
                    schrieb am zuletzt editiert von
                    #121

                    @PLCHome-0 Die Schnittstelle habe schon kontrolliert, dmesg zeigt da keine Aufälligkeiten: USB ran, wird erkannt und dann ist stille. Hab heute morgen einen Waveshare mit RS232/485/TTL geordert (den brauche ich noch für andere Projekt) und einen billigen USB Adapter mit Prolific Chipsatz, kommt morgen.
                    Wie gesagt iobroker läuft in einem LXC (Proxmox Host) und ttyUSB0 ist direkt durchgereicht. Den Aufbau hab ich mit verschiedenen USB Geräten am laufen da gibt es keine Probleme.
                    Wenn ich die Schnittstelle z.B. mit screen /dev/ttyUSB0 115200 öffne, kann ich jeden Befehl ohne Probleme absetzen und sehe auch keine Übertragungsfehler. Die Befehle bat, info, pwr, soh, stat, time, ver schließen direkt mit "Command completed successfully" ab:

                    Command completed successfully
                    $$
                    PYTES>
                    

                    Bei help undlog braucht es ein Bestätigung der Abschnitte mit ENTER

                    PYTES>log
                    @
                     Index   : 29    
                     Time    : 24-02-22 11:41:23
                     ModID   : BMM
                     Code    : 1c5
                     Info    : The device start charging.
                    
                     Index   : 28    
                     Time    : 24-02-22 11:36:37
                     ModID   : BMM
                     Code    : 1c4
                     Info    : The device start charging.
                    
                     Index   : 27    
                     Time    : 24-02-22 11:30:09
                     ModID   : BMM
                     Code    : 1c3
                     Info    : The device start charging.
                    Press [Enter] to be continued,other key to exit
                    

                    Ich hab jetzt keine tiefere Analyse gemacht: Wartet dein Code oder wertet er die Zeile aus? Welchen Indikator nimmst du um festzustellen das ein Abfrage fertig ist, also zB info.

                    Ich hoffe du hast noch ein wenig Geduld mit mir...

                    PLCHome 0P 1 Antwort Letzte Antwort
                    0
                    • B bios123

                      @PLCHome-0 Die Schnittstelle habe schon kontrolliert, dmesg zeigt da keine Aufälligkeiten: USB ran, wird erkannt und dann ist stille. Hab heute morgen einen Waveshare mit RS232/485/TTL geordert (den brauche ich noch für andere Projekt) und einen billigen USB Adapter mit Prolific Chipsatz, kommt morgen.
                      Wie gesagt iobroker läuft in einem LXC (Proxmox Host) und ttyUSB0 ist direkt durchgereicht. Den Aufbau hab ich mit verschiedenen USB Geräten am laufen da gibt es keine Probleme.
                      Wenn ich die Schnittstelle z.B. mit screen /dev/ttyUSB0 115200 öffne, kann ich jeden Befehl ohne Probleme absetzen und sehe auch keine Übertragungsfehler. Die Befehle bat, info, pwr, soh, stat, time, ver schließen direkt mit "Command completed successfully" ab:

                      Command completed successfully
                      $$
                      PYTES>
                      

                      Bei help undlog braucht es ein Bestätigung der Abschnitte mit ENTER

                      PYTES>log
                      @
                       Index   : 29    
                       Time    : 24-02-22 11:41:23
                       ModID   : BMM
                       Code    : 1c5
                       Info    : The device start charging.
                      
                       Index   : 28    
                       Time    : 24-02-22 11:36:37
                       ModID   : BMM
                       Code    : 1c4
                       Info    : The device start charging.
                      
                       Index   : 27    
                       Time    : 24-02-22 11:30:09
                       ModID   : BMM
                       Code    : 1c3
                       Info    : The device start charging.
                      Press [Enter] to be continued,other key to exit
                      

                      Ich hab jetzt keine tiefere Analyse gemacht: Wartet dein Code oder wertet er die Zeile aus? Welchen Indikator nimmst du um festzustellen das ein Abfrage fertig ist, also zB info.

                      Ich hoffe du hast noch ein wenig Geduld mit mir...

                      PLCHome 0P Offline
                      PLCHome 0P Offline
                      PLCHome 0
                      Developer
                      schrieb am zuletzt editiert von PLCHome 0
                      #122

                      @bios123 sagte in Test Adapter Pylontech v0.0.8:

                      Ich hoffe du hast noch ein wenig Geduld mit mir...

                      Danke, dass du dir Gedanken machst. Aber einen Adapter, der nicht funktioniert, den braucht keiner :-)

                      @bios123 sagte in Test Adapter Pylontech v0.0.8:

                      Welchen Indikator nimmst du um festzustellen das ein Abfrage fertig ist, also zB info.

                          while ((position = data.lastIndexOf('$$')) !== -1) {
                            if ((start = data.lastIndexOf('>', position)) !== -1) {
                              this.push(data.subarray(start, position - 1));
                            }
                      

                      Der Code wertet alles zwischen > und $$ aus.

                      if ((position = data.lastIndexOf('[Enter]')) !== -1) {
                            data.write('-------', position);
                            this.emit('needsenddata', '\r');
                          }
                      

                      Wenn er [Enter] empängt, ersetzt er es mit - und sendet ein \r, das wird für das Log benötigt.

                      Alles in ConsolenReader.ts zu finden.

                      --

                      Was ich komisch finde, ist das i1.
                      Was man im Log sieht, ist das echo. Das bedeutet, man sendet ein Zeichen an den Akku und dieser sendet es zurück.

                      @Radi hatte auch ein Problem mit dem Kabel. @Radi, vielleicht kannst du noch mal bescheriben, was genau der Fehler war?

                      Da hat sich der Adapter doch auch total komisch verhalten. Es fehlten Zeichen und es waren welche da, die da nicht hingehörten.

                      1 Antwort Letzte Antwort
                      0
                      • B bios123

                        @PLCHome-0 die alten Objekte hatte ich bereits gelöscht um sicher zu gehen das alles sauber angelegt wird. SOH und STAT hab ich wie beschrieben ausgeschaltet. Das hilft aber nicht wirklich. Der Adapter ruft die Daten mal ab und mal nicht. Ich habe versucht den blockierenden Punkt zu finden. Das Kommando 'pwr' wird geschickt und ein Antwort gibt es auch, danach dann wieder Error: timeout. Ich vermute 'pwr' kann ich mit 'Batteriestromdaten herunterladen' abschalten? Wie schnell rufst du die Daten ab? Eventuell braucht die Pytes V5 nach jeder Anfrage einen Moment. Ich kann das zumindest nicht nachstellen, wenn ich manuell hintereinader ein Request abschicke. Ich rufe übrigens direkt per /dev/ttyUSB0 ab, Interface hängt am iobroker und 'US series' ist ausgewählt.

                        
                        pylontech.0
                        2024-02-21 11:19:04.886	error	Error: timeout
                        
                        pylontech.0
                        2024-02-21 11:18:59.932	silly	if
                        
                        pylontech.0
                        2024-02-21 11:18:59.884	silly	16 - - - - - - - Absent - - - - - - - - - Command completed successfully $$ PYTES>
                        
                        pylontech.0
                        2024-02-21 11:18:59.852	silly	- - Absent - - - - - - - - - 14 - - - - - - - Absent - - - - - - - - - 15 - - - - - - - Absent - - - - - - - - -
                        
                        pylontech.0
                        2024-02-21 11:18:59.810	silly	- - - - - - 11 - - - - - - - Absent - - - - - - - - - 12 - - - - - - - Absent - - - - - - - - - 13 - - - - -
                        
                        pylontech.0
                        2024-02-21 11:18:59.766	silly	- 8 - - - - - - - Absent - - - - - - - - - 9 - - - - - - - Absent - - - - - - - - - 10 - - - - - - - Absent - - -
                        
                        pylontech.0
                        2024-02-21 11:18:59.723	silly	- - - - - - Absent - - - - - - - - - 6 - - - - - - - Absent - - - - - - - - - 7 - - - - - - - Absent - - - - - - - -
                        
                        pylontech.0
                        2024-02-21 11:18:59.680	silly	- - - - - - - - 3 - - - - - - - Absent - - - - - - - - - 4 - - - - - - - Absent - - - - - - - - - 5 -
                        
                        pylontech.0
                        2024-02-21 11:18:59.397	silly	PYTES> PYTES>pwr @ Power Volt Curr Tempr Tlow Thigh Vlow Vhigh Base.St Volt.St Curr.St Temp.St Coulomb Time B.V.St B.T.St Barcode DevType 1 53708 2164 24000 19000 19000 3352 3359 Charge Normal Normal Normal 52% 2024-02-21 18:15:57 Normal Normal ES1000XXXP010XXX E-BOX-48100V-D 2 - - - - - - - Absent -
                        

                        Gruß Markus

                        PLCHome 0P Offline
                        PLCHome 0P Offline
                        PLCHome 0
                        Developer
                        schrieb am zuletzt editiert von PLCHome 0
                        #123

                        @bios123 sagte in Test Adapter Pylontech v0.0.8:

                        Wie schnell rufst du die Daten ab? Eventuell braucht die Pytes V5 nach jeder Anfrage einen Moment.

                        Also wenn du eine Pause ausprobieren möchtest, dann kannst du folgende Zeile einfügen:

                        setTimeout(()=>{....},1000);
                        

                        **Editiert

                        1000 ist die Wartezeit in ms.

                        File build/pylontech/WorkerAbstract.js

                        Alt:

                          _nextcommand() {
                            debugApi("MyWorkerAbstract._nextcommand", "this._activeCmd:", this._activeCmd, "this._started:", this._started);
                            if (!this._activeCmd && this._started) {
                              this._activeCmd = this._commands.shift();
                              if (this._activeCmd) {
                                this._parsers.setCMD(this._activeCmd.cmd);
                                this.sendData(this._activeCmd.cmd + "\r");
                                this._activeCmd.timeout = setTimeout(this._ontimeout.bind(this), this._timeout);
                              }
                            }
                          }
                        

                        Neu:

                          _nextcommand() {
                            debugApi("MyWorkerAbstract._nextcommand", "this._activeCmd:", this._activeCmd, "this._started:", this._started);
                            if (!this._activeCmd && this._started) {
                              this._activeCmd = this._commands.shift();
                              if (this._activeCmd) {
                                setTimeout(()=>{
                                  this._parsers.setCMD(this._activeCmd.cmd);
                                  this.sendData(this._activeCmd.cmd + "\r");
                                  this._activeCmd.timeout = setTimeout(this._ontimeout.bind(this), this._timeout);
                                },1000);
                              }
                            }
                          }
                        

                        **Editiert

                        Pass bitte auf das sich der Adapter nicht überholt. Das Abfrageintervall kann man in der Konfiguration einstellen. Aktuell hatte ich da nichts vorgesehen, da durch die Timeout der Abruf nicht länger als 1 Minute dauern konnte.

                        B 1 Antwort Letzte Antwort
                        0
                        • PLCHome 0P PLCHome 0

                          @bios123 sagte in Test Adapter Pylontech v0.0.8:

                          Wie schnell rufst du die Daten ab? Eventuell braucht die Pytes V5 nach jeder Anfrage einen Moment.

                          Also wenn du eine Pause ausprobieren möchtest, dann kannst du folgende Zeile einfügen:

                          setTimeout(()=>{....},1000);
                          

                          **Editiert

                          1000 ist die Wartezeit in ms.

                          File build/pylontech/WorkerAbstract.js

                          Alt:

                            _nextcommand() {
                              debugApi("MyWorkerAbstract._nextcommand", "this._activeCmd:", this._activeCmd, "this._started:", this._started);
                              if (!this._activeCmd && this._started) {
                                this._activeCmd = this._commands.shift();
                                if (this._activeCmd) {
                                  this._parsers.setCMD(this._activeCmd.cmd);
                                  this.sendData(this._activeCmd.cmd + "\r");
                                  this._activeCmd.timeout = setTimeout(this._ontimeout.bind(this), this._timeout);
                                }
                              }
                            }
                          

                          Neu:

                            _nextcommand() {
                              debugApi("MyWorkerAbstract._nextcommand", "this._activeCmd:", this._activeCmd, "this._started:", this._started);
                              if (!this._activeCmd && this._started) {
                                this._activeCmd = this._commands.shift();
                                if (this._activeCmd) {
                                  setTimeout(()=>{
                                    this._parsers.setCMD(this._activeCmd.cmd);
                                    this.sendData(this._activeCmd.cmd + "\r");
                                    this._activeCmd.timeout = setTimeout(this._ontimeout.bind(this), this._timeout);
                                  },1000);
                                }
                              }
                            }
                          

                          **Editiert

                          Pass bitte auf das sich der Adapter nicht überholt. Das Abfrageintervall kann man in der Konfiguration einstellen. Aktuell hatte ich da nichts vorgesehen, da durch die Timeout der Abruf nicht länger als 1 Minute dauern konnte.

                          B Offline
                          B Offline
                          bios123
                          schrieb am zuletzt editiert von
                          #124

                          @plchome-0

                          host.iobroker
                          2024-02-23 09:14:28.602	error	Caught by controller[0]: SyntaxError: await is only valid in async functions and the top level bodies of modules
                          host.iobroker
                          2024-02-23 09:14:28.602	error	Caught by controller[0]: ^^^^^
                          host.iobroker
                          2024-02-23 09:14:28.602	error	Caught by controller[0]: await new Promise((a)=>{setTimeout(a,1000)});
                          host.iobroker
                          2024-02-23 09:14:28.602	error	Caught by controller[0]: /opt/iobroker/node_modules/iobroker.pylontech/build/pylontech/WorkerAbstract.js:72
                          

                          so leider nicht.

                          PLCHome 0P 1 Antwort Letzte Antwort
                          0
                          • B bios123

                            @plchome-0

                            host.iobroker
                            2024-02-23 09:14:28.602	error	Caught by controller[0]: SyntaxError: await is only valid in async functions and the top level bodies of modules
                            host.iobroker
                            2024-02-23 09:14:28.602	error	Caught by controller[0]: ^^^^^
                            host.iobroker
                            2024-02-23 09:14:28.602	error	Caught by controller[0]: await new Promise((a)=>{setTimeout(a,1000)});
                            host.iobroker
                            2024-02-23 09:14:28.602	error	Caught by controller[0]: /opt/iobroker/node_modules/iobroker.pylontech/build/pylontech/WorkerAbstract.js:72
                            

                            so leider nicht.

                            PLCHome 0P Offline
                            PLCHome 0P Offline
                            PLCHome 0
                            Developer
                            schrieb am zuletzt editiert von PLCHome 0
                            #125

                            @bios123 sagte in Test Adapter Pylontech v0.0.8:

                            so leider nicht.

                            Ups sorry ich habs oben korrigiert :-(

                            Ich sagte ja, eine Pause ist nicht so trivial.

                            B 1 Antwort Letzte Antwort
                            0
                            • PLCHome 0P PLCHome 0

                              @bios123 sagte in Test Adapter Pylontech v0.0.8:

                              so leider nicht.

                              Ups sorry ich habs oben korrigiert :-(

                              Ich sagte ja, eine Pause ist nicht so trivial.

                              B Offline
                              B Offline
                              bios123
                              schrieb am zuletzt editiert von
                              #126

                              @plchome-0 Kurzer Zwischenstand mit der Codeanpassung scheint es zu funktionieren. Ich lasse das mal so über Nacht laufen. Bin etxra auf 1 Minute Intervall runter und habe mich bei setTimeout(()=>{....},100); auf 100 Millisekunden rangetastet. Sobald ich die anderen USB-Serial Wandler habe, wird aber nochmal ohne Pause getestet.

                              PLCHome 0P 1 Antwort Letzte Antwort
                              0
                              • B bios123

                                @plchome-0 Kurzer Zwischenstand mit der Codeanpassung scheint es zu funktionieren. Ich lasse das mal so über Nacht laufen. Bin etxra auf 1 Minute Intervall runter und habe mich bei setTimeout(()=>{....},100); auf 100 Millisekunden rangetastet. Sobald ich die anderen USB-Serial Wandler habe, wird aber nochmal ohne Pause getestet.

                                PLCHome 0P Offline
                                PLCHome 0P Offline
                                PLCHome 0
                                Developer
                                schrieb am zuletzt editiert von
                                #127

                                @bios123 Kannst vielleicht auch mal mit 10ms probieren.

                                In 100ms kann die Schnittstelle schon 1152 Zeichen übertragen. Da könnte dir der Akku ja schon seine ganze Lebensgeschichte erzählen :-)

                                115200 Baud 8n1 macht 1 Start + 8 Datenbit + kein Parity Bit + 1 Stop Bit, also 1+8+0+1 = 10 Bit für ein Zeichen, also 11520 Zeichen pro Sekunde im Maximum.

                                Ich gucke mir das mal an und werde die Wartezeit einmal pflegbar machen.

                                1 Antwort Letzte Antwort
                                0
                                • B Offline
                                  B Offline
                                  bios123
                                  schrieb am zuletzt editiert von
                                  #128

                                  @PLCHome-0 Update: Neben meinem Consolenkabel (USB->RJ45) mit FTDI Chip, habe ich noch einen
                                  Waveshare FT232RNL (FTDI), UGREEN mit PL2303 (Prolific) und den besagten LogiLink AU0034 (FTDI) zur Verfügung. Bei dem PL2303 werden offensichtlich immer nur kleine Datenmengen eingelesen und es gibt das totale Chaoslog. Bei den FDTI Konsorten kann ich keine wesentliche Unterschiede feststellen. Im weiteren Verlauf wurde der LogiLink benutzt.

                                  Kommen wir mal zurück zum Problem: Egal ob mit Pause oder ohne, es kommen immer wieder Timeouts. Abfrageintervalle getestet 1, 3 und 5 Minuten ohne/mit Pause von 100 ms bis 1000 ms. Die Tendenz, dass die Abfrage in einen Timeout läuft, ist ohne Pause auf jeden Fall höher. Mit Pause von 1000 ms und 5 Minuten Intervallen läuft der Adapter 2, 3 oder auch 5 Stunden ohne Probleme. Es kann aber auch passieren das ein oder mehrer Timouts hintereinader stattfinden und danach läufts wiede für 3 Stunden.
                                  Welche Informationen gerade abgerufen werden scheint auch unerheblich zu sein. Abbrüche hatte ich sowohl bei pwr, bat, log, info und time.

                                  Um wirklich sicher auszuschließen das es mit der Schnittstelle nix zu tun hat, habe ich kurzerhand ser2net bemüht und die Daten nicht direkt geholt. Das hat leider gar keinen Unterschied gemacht.

                                  So langsam gehen mir die Ideen aus, bis auf die Tatsache das eine Pytes-V5 an der Console nicht dafür gemacht zu seien scheint. Die Abfragen für soh, stat waren immer inaktiv beim testen. Hier müsste für stat ja noch eine Anpassung rein das es die Abfrage stat 1 nicht gibt.

                                  PLCHome 0P 1 Antwort Letzte Antwort
                                  0
                                  • B bios123

                                    @PLCHome-0 Update: Neben meinem Consolenkabel (USB->RJ45) mit FTDI Chip, habe ich noch einen
                                    Waveshare FT232RNL (FTDI), UGREEN mit PL2303 (Prolific) und den besagten LogiLink AU0034 (FTDI) zur Verfügung. Bei dem PL2303 werden offensichtlich immer nur kleine Datenmengen eingelesen und es gibt das totale Chaoslog. Bei den FDTI Konsorten kann ich keine wesentliche Unterschiede feststellen. Im weiteren Verlauf wurde der LogiLink benutzt.

                                    Kommen wir mal zurück zum Problem: Egal ob mit Pause oder ohne, es kommen immer wieder Timeouts. Abfrageintervalle getestet 1, 3 und 5 Minuten ohne/mit Pause von 100 ms bis 1000 ms. Die Tendenz, dass die Abfrage in einen Timeout läuft, ist ohne Pause auf jeden Fall höher. Mit Pause von 1000 ms und 5 Minuten Intervallen läuft der Adapter 2, 3 oder auch 5 Stunden ohne Probleme. Es kann aber auch passieren das ein oder mehrer Timouts hintereinader stattfinden und danach läufts wiede für 3 Stunden.
                                    Welche Informationen gerade abgerufen werden scheint auch unerheblich zu sein. Abbrüche hatte ich sowohl bei pwr, bat, log, info und time.

                                    Um wirklich sicher auszuschließen das es mit der Schnittstelle nix zu tun hat, habe ich kurzerhand ser2net bemüht und die Daten nicht direkt geholt. Das hat leider gar keinen Unterschied gemacht.

                                    So langsam gehen mir die Ideen aus, bis auf die Tatsache das eine Pytes-V5 an der Console nicht dafür gemacht zu seien scheint. Die Abfragen für soh, stat waren immer inaktiv beim testen. Hier müsste für stat ja noch eine Anpassung rein das es die Abfrage stat 1 nicht gibt.

                                    PLCHome 0P Offline
                                    PLCHome 0P Offline
                                    PLCHome 0
                                    Developer
                                    schrieb am zuletzt editiert von
                                    #129

                                    @bios123 sagte in Test Adapter Pylontech v0.0.8:

                                    soh, stat

                                    Ja, die beiden gibt es so nicht, die solltest du ausschalten, damit es keine Irritationen gibt. stat unterscheidet sich auch zum Pylontech, da dort die stat pro Akku ausgegeben wird. Die Abfrage stat oder stat 1 sendet dort die Abfrage des ersten Akkus.

                                    Aber eigentlich sollten diese Abfragen kein Problem darstellen, da sie mit > beginnen und mit $$ aufhören. Es finden sich nur keine Treffer mit den regex.

                                    Das mit dem timeout ist irgendwie seltsam. Weil es zeitweise funktioniert und zeitweise nicht. Der Pylontch läuft mir ab und zu auch auf ein timeout so alle ein bis zwei Tage eine Abfrage. Ich dachte immer, es liegt bei mir am Wlan. Aber auch mit dem FTDI bekomme ich die Fehler auch alle ein bis zwei Tage mal.

                                    Es kann natürlich sein, dass der Akku nicht gleichzeitig mit zwei Geräten kommunizieren möchte und die Konsole dann keine Antwort bekommt, wenn er gerade mit dem Inverter quasselt.

                                    Ich muss mal schauen, ob es eine elegante Lösung gibt, im Falle eines Timeout das letzte Kommando zu wiederholen.

                                    Und wie ich eine Verriegelung umsetzte, dass sich das Intervall nicht überholt.

                                    Ich hätte allerdings nicht gedacht, dass es nicht dem nicht passenden Regex noch so viele Probleme gibt

                                    1 Antwort Letzte Antwort
                                    0
                                    • B Offline
                                      B Offline
                                      bios123
                                      schrieb am zuletzt editiert von
                                      #130

                                      @PLCHome-0 Noch eine kleine Anmerkung, da passt die Zuordnung nicht. Muss ich mal beobachten ob das nur bei 100% auftritt (habe den Fall mit fetchCmdSerial.js gesichert):

                                      State value to set for "pylontech.0.ES1000626P010443.battery16.coulomb" has to be type "number" but received type "string"
                                      

                                      5c9ad831-eae9-4530-94df-78d6ecedcf89-image.png
                                      6a42d8e2-bad1-430f-a9f8-d30c08b3fe5e-image.png

                                      PLCHome 0P 1 Antwort Letzte Antwort
                                      0
                                      • B bios123

                                        @PLCHome-0 Noch eine kleine Anmerkung, da passt die Zuordnung nicht. Muss ich mal beobachten ob das nur bei 100% auftritt (habe den Fall mit fetchCmdSerial.js gesichert):

                                        State value to set for "pylontech.0.ES1000626P010443.battery16.coulomb" has to be type "number" but received type "string"
                                        

                                        5c9ad831-eae9-4530-94df-78d6ecedcf89-image.png
                                        6a42d8e2-bad1-430f-a9f8-d30c08b3fe5e-image.png

                                        PLCHome 0P Offline
                                        PLCHome 0P Offline
                                        PLCHome 0
                                        Developer
                                        schrieb am zuletzt editiert von PLCHome 0
                                        #131

                                        @bios123 sagte in Test Adapter Pylontech v0.0.8:

                                        Muss ich mal beobachten ob das nur bei 100% auftritt (habe den Fall mit fetchCmdSerial.js gesichert):

                                        Wird wohl da da sonst nicht 100000mAh stehen. Bei 99% sind im Accu 99000mAh, dann passt der RegEx.

                                        /build/pylontech/ParserUSBatN.js

                                        aus

                                        const rowB = /^(.{9})(.{9})(.{9})(.{13})(.{13})(.{13})(.{13})(.{10})(.{9,16})?(.{1,3})?/gm;
                                        

                                        wird

                                        const rowB = /^(.{9})(.{9})(.{9})(.{13})(.{13})(.{13})(.{13})(.{9})(.{10,17})?(.{1,3})?/gm;
                                        

                                        Ja, das ist dann ein String weil "100% 1" nicht als Zahl erkannt wird.

                                        1 Antwort Letzte Antwort
                                        0
                                        • B Offline
                                          B Offline
                                          bios123
                                          schrieb am zuletzt editiert von
                                          #132

                                          @PLCHome-0 Mit dem angepassten RegEx scheint es zu passen, habe keine Meldung mehr bekommen.

                                          Unter pylontech.0.ES1000626P010443.power.power_events erwartet der Adpater ebenfalls eine Zahl.

                                          65a4e5c2-2093-4279-a6f3-896d7cbcd677-image.png

                                          Mir is noch nicht ganz klar was "0x8000000 DSG" bedeutet, muss ich mal weiter beobachten falls es nochnmal kommt.

                                          PLCHome 0P 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          833

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe