FHEM Forum

FHEM => Frontends => FHEMapp => Thema gestartet von: Doogy am 15 August 2024, 15:35:06

Titel: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Doogy am 15 August 2024, 15:35:06
Hallo zusammen,

FHEMapp läuft bei mir jetzt schon seit längerem. Heute Nacht hat sich allerdings FHEM in einer Bootschleife befunden (FHEM startete 23x neu, im Minutentakt) und ist dauernd abgestürzt. Erst ein Reboot des Linux konnte Abhilfe schaffen. Könnte mir eventuell dazu jemand helfen, damit es nicht wieder passiert.

Meldung im logfile:
malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "\r\n<...") at ./FHEM/02_FHEMAPP.pm line 937.
VG Felix
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Otto123 am 15 August 2024, 15:58:55
Hallo Felix,

Zitat von: Doogy am 15 August 2024, 15:35:06Könnte mir eventuell dazu jemand helfen, damit es nicht wieder passiert.
der Modulauthor sollte eine Prüfung der JSON Strings einbauen. Das ist ein bekanntes Problem bei der Verwendung von decode_json.

Beispiel:
sub decode_j {
# decode_json() croaks on error, this function should prevent fhem crashes
# https://metacpan.org/pod/Perl::Critic::Policy::ErrorHandling::RequireCheckingReturnValueOfEval
  use JSON qw(decode_json);
  my $maybe_json = shift;
  my $data;
  if ( eval { $data = decode_json($maybe_json); 1 } ) { return $data }
  Log3(undef, 1, "JSON decoding error, >$maybe_json< seems not to be valid JSON data: $@");
  return q{}
}

Gruß Otto
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: jemu75 am 16 August 2024, 16:06:01
Hallo Felix,

die Anpassung in dem Modul müsste sich @Benni mal ansehen. Unabhängig davon würde ich mir deine Konfiguration gern mal ansehen. Im Normalfall wird diese ja in FHEMApp erzeugt und dann an FHEM übergeben. Das FHEM Modul übernimmt hier hauptsächlich das Speichern bzw. Laden der Konfiguration auf dem FHEM-Server.

Also sende mir gern mal deine Konfiguration (unter /home/jens/extfhem/opt/fhem/conf/ xxx_config.fhemapp.json) zu finden.

Beste Grüße
Jens :)
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Doogy am 16 August 2024, 16:55:30
Hallo Jens,

hier die gewünschte Datei.

Nochmal festzuhalten, bis jetzt war es ein einmaliges "Event". Seit dem kompletten Neustart läuft erstmal wieder alles.

VG Felix
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Himbi777 am 17 August 2024, 15:14:26
Zitat von: Doogy am 15 August 2024, 15:35:06Hallo zusammen,

FHEMapp läuft bei mir jetzt schon seit längerem. Heute Nacht hat sich allerdings FHEM in einer Bootschleife befunden (FHEM startete 23x neu, im Minutentakt) und ist dauernd abgestürzt. Erst ein Reboot des Linux konnte Abhilfe schaffen. Könnte mir eventuell dazu jemand helfen, damit es nicht wieder passiert.

Meldung im logfile:
malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "\r\n<...") at ./FHEM/02_FHEMAPP.pm line 937.
VG Felix

Hallo Jens
Bei mir war es genauso, Fhem hat in der gleichen Nacht von 1:12 bis 1:37 auch 22x neu gestartet, lief aber ab dann wieder normal weiter.
Ich habe die gleiche Fehlermeldung im LOG-File gefunden.

Gruß Gerhard
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Doogy am 17 August 2024, 17:07:01
Sogar die Uhrzeit war gleich!
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: OliS. am 17 August 2024, 23:08:15
Jupp, bei mir auch. Derselbe Zeitraum, dasselbe Verhalten.

LG
Oli
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Benni am 20 August 2024, 21:51:53
Sorry, dass ich mich erst jetzt dazu melde! Aber wie so viele, befinde ich mich aktuell eher im Sommer-Urlaubs-Modus ;)

Das wichtigste zuerst: Das Problem wurde NICHT durch die FHEMApp-Config ausgelöst, sondern durch eine ungültige JSON-Antwort bei der (zyklischen) Abfrage der Releases von github.

Das erklärt woh auch die scheinbare Gleichzeitigkeit bei verschiedenen Usern. Wahrscheinlich war auch weder ein reboot die Problemlösung sondern github hat einfach ab einem bestimmten Zeitpunkt wieder eine gültige json-Antwort ausgeliefert.

Btw.: Das Modul verarbeitet die FHEMApp-Config bisher überhaupt nicht. Warum auch?

@Otto123: Danke für den Hinweis! Das werde ich in die nächste Version aufnehmen. Kann aber noch ein paar Tage dauern ... Developer machen eben eher Sommerschlaf, als Winterschlaf :D

gb#

PS: Um das in der Zwischenzeit zu verhindern, kann das Modul per attribut disabled davon abgehalten werden, zyklisch die Release-Daten bei github abzurufen, um auf updates zu prüfen.
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Beta-User am 05 Februar 2025, 18:26:21
Hallo zusammen,

nachdem ich die Tage über ein etwas anders gelagertes Problem im Modul mit unmotivierten Neustarts gestolpert bin (https://forum.fhem.de/index.php?topic=140666.0), hier eine gepatchte Fassung in der Hoffnung, dass sich Benni dann wieder des Themas annimmt.

PS: Bitte dann FHEM neu starten, der interne timer-update-Mechanismus ist leicht geändert...
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Benni am 06 Februar 2025, 21:20:34
Hallo Jörg,

danke für den Hinweis und Danke fürs Patchen!
Werde ich mir gerne anschauen und umsetzen ;)

gb#
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Beta-User am 07 Februar 2025, 08:01:16
Hi Benni,

Danke, dass du dich der Sache annimmst! (der "patch" ist leider eher sowas wie ein hotfix, ich wollte vor allem auf die schnelle Art diese FHEM-restarts vermeiden und habe daher einfach kurz zusammengeklaubt, was mir irgendwann mal in der Vergangenheit dazu über den Weg gelaufen war...)
Titel: Aw: Absturz FHEM vermutlich durch FHEMapp
Beitrag von: Benni am 02 März 2025, 12:43:19
Hallo zusammen!

Den Patch von Jörg habe ich inzwischen weitgehend übernommen und nach kurzem Test nun ins SVN eingecheckt.
Der sollte dann ab Morgen früh per update verfügbar sein.

Damit haben sich die ungewollten Neustarts nun hoffentlich endgültig erledigt ;)

s.a.: https://forum.fhem.de/index.php?topic=138697.msg1335538#msg1335538

Schönes Rest-Wochenende zusammen!
gb#