[SOLVED] MQTT2_CLIENT set connect blockiert FHEM

Begonnen von knorxi, 02 Februar 2022, 10:29:43

Vorheriges Thema - Nächstes Thema

knorxi

Ich habe einen Saugroboter von Roomba den ich über dem MQTT2_CLIENT anspreche.
Bei einem "set RoombiClient connect" braucht er ziemliche lange (ca. 4s) um eine SSL-Verbindung aufzubauen.
Deshalb habe ich den TIMEOUT auf 6s gestellt.
Während des Verbidnungaufbaus wird FHEM blockiert.
Das verstehe ich nicht, da der MQTT2_CLIENT in der Funktion MQTT2_CLIENT_connect doch non-blocking DevIo_OpenDev in DevIo.pm aufruft.
DevIo_OpenDev ruft dann auch non-blocking HttpUtils_Connect in HttpUtils.pm auf.
Hier mal ein list vom MQTT2_CLIENT RoombiClient:

Internals:
   BUF       
   Clients    :MQTT2_DEVICE:MQTT_GENERIC_BRIDGE:
   ClientsKeepOrder 1
   DEF        192.168.178.43:8883
   DeviceName 192.168.178.43:8883
   FD         64
   FUUID      600996a7-f33f-8d65-624c-1562fe6d5b5a71bc
   NAME       RoombiClient
   NR         432
   PARTIAL   
   SSL        1
   STATE      opened
   TIMEOUT    6
   TYPE       MQTT2_CLIENT
   WBCallback
   clientId   ...
   lastMsgTime 1643791806.38411
   nextOpenDelay 5
   MatchList:
     1:MQTT2_DEVICE ^.
     2:MQTT_GENERIC_BRIDGE ^.
   READINGS:
     2022-02-02 08:51:43   state           opened
   sslargs:
     SSL_version TLSv1_2
Attributes:
   SSL        1
   autocreate no
   clientId   ...
   connectTimeout 6
   mqttVersion 3.1.1
   room       Gästezimmer
   sslargs    SSL_version:TLSv1_2
   username   ...


Wenn ich folgendes in FHEM eingebe:

{main::Log 1, 'set RoombiClient connect'};
set RoombiClient connect;
{main::Log 1, 'sleep 0s'};
sleep 1;
{main::Log 1, 'sleep 1s'};

Dann steht im Log das:

2022.02.02 10:19:15 1: set RoombiClient connect
2022.02.02 10:19:15 5: HttpUtils url=https://192.168.178.43:8883/ NonBlocking via https
2022.02.02 10:19:15 4: IP: 192.168.178.43 -> 192.168.178.43
2022.02.02 10:19:15 1: sleep 0s
2022.02.02 10:19:20 5: RoombiClient: sending CONNECT (16)N(0)(4)MQTT(4)...
2022.02.02 10:19:20 5: DevIo_SimpleWrite RoombiClient: 10..
2022.02.02 10:19:20 1: 192.168.178.43:8883 reappeared (RoombiClient)
2022.02.02 10:19:20 1: Callback fired
2022.02.02 10:19:20 1: [Freezemon] Freezemon: possible freeze starting at 10:19:16, delay is 4.476 possibly caused by: no bad guy found :-(
2022.02.02 10:19:20 1: sleep 1s
2022.02.02 10:19:20 5: RoombiClient: received CONNACK (0)(0)

Zwischen "set RoombiClient connect" und "sleep 1s" sollte nur 1s vergehen. Es sind aber 5s.
Habe ich hier einen Denkfehler?
Weiß jemand, wie das Blockieren verhindert werden kann?

rudolfkoenig

HttpUtils_Connect ist nicht ganz blockierungsfrei: das Aushandeln der SSL-Verbindungsparameter passiert in der Bibliothek, und ist blockierend.

Ob in diesem Fall das Blockieren daran liegt, kann man vmtl. mit weiteren Debug-Zeilen in HttpUtils.pm, rund um den start_SSL Aufruf rausfinden. Wenn das stimmt, und jemand eine Idee hat, wie man das blockierungsfrei gestalten kann, bitte melden. Die Bibliothek neu zu implementieren ist aber keine Option :)

knorxi

Danke für die Aufklärung! Das macht dann Sinn.
Habe um SSL->start_SSL folgende Debug-Zeilen eingetragen:

      Log3 $hash, 1, "before calling IO::Socket::SSL->start_SSL";
      eval {
        IO::Socket::SSL->start_SSL($hash->{conn}, \%par) || undef $hash->{conn};
      };
      Log3 $hash, 1, "after call of IO::Socket::SSL->start_SSL";

Im Log steht dann das:

2022.02.02 15:45:19 1: before calling IO::Socket::SSL->start_SSL
2022.02.02 15:45:24 1: after call of IO::Socket::SSL->start_SSL

Daran scheint es also zu liegen.
Es wäre natürlich toll, wenn jemand eine Idee hätte  :-*
Ich sehe ein, dass das Ändern der Bibliothek keine Option ist  ;)

knorxi

#3
Ich habe mal rumgesucht und das hier gefunden:
https://docplayer.org/573367-Io-socket-ssl-ssl-leicht-gemacht-so-gut-es-geht.html
Auf Seite 40 gibt es die Folie: "Fortgeschrittene Nutzung:- non-blocking connect (Client)"
Habe den Code mal so um das start_SSL eingebaut:

      Log3 $hash, 1, "before calling IO::Socket::SSL->start_SSL";
#      eval {
#        IO::Socket::SSL->start_SSL($hash->{conn}, \%par) || undef $hash->{conn};
#      };

      # nonblocking connect
      # erst non-blocking INET-Connect machen
      # dann non-blocking SSL-Upgrade
      # Upgrade
      $hash->{conn}->blocking(0);
      $par{SSL_startHandshake} = 0;
      IO::Socket::SSL->start_SSL($hash->{conn}, \%par);
      while (1) {
        Time::HiRes::sleep(1); # 1 second
        Log3 $hash, 1, "Wait for SSL->connect";
        $hash->{conn}->connect_SSL && last;        # connect fertig
        die "$!,$SSL_ERROR" if ! $!{EAGAIN}; # Fehler
        if ( $SSL_ERROR == SSL_WANT_READ ) {
          #... warten auf socket readable (select loop...)
        } elsif ( $SSL_ERROR == SSL_WANT_WRITE ) {
          #... warten auf Socket writable
        }
      }


Leider weiß ich nicht genau bzw. überhaupt nicht was ich tue  :-[.
Das Freeze bleibt zwar, aber das connect scheint jetzt non-blocking zu sein.
Zumindest wird ins Log im Sekundentakt geschrieben.
Vielleicht könnt ihr damit etwas anfangen, um es wirklich non-blocking zu machen....

2022.02.02 16:56:11 1: before calling IO::Socket::SSL->start_SSL
2022.02.02 16:56:12 1: Wait for SSL->connect
2022.02.02 16:56:13 1: Wait for SSL->connect
2022.02.02 16:56:14 1: Wait for SSL->connect
2022.02.02 16:56:15 1: Wait for SSL->connect
2022.02.02 16:56:16 1: Wait for SSL->connect
2022.02.02 16:56:17 1: Wait for SSL->connect
2022.02.02 16:56:18 1: Wait for SSL->connect
2022.02.02 16:56:18 1: after call of IO::Socket::SSL->start_SSL
2022.02.02 16:56:18 1: 192.168.178.43:8883 reappeared (RoombiClient)
2022.02.02 16:56:18 2: [Freezemon] Freezemon: possible freeze starting at 16:56:12, delay is 6.648 possibly caused by: no bad guy found :-(


Edit: Merke gerade, dass ich etwas vom Roombi empfangen kann, aber ein "update checktime" nicht mehr funktioniert:

"Downloading https://fhem.de/fhemupdate/controls_fhem.txt

fhem
https://fhem.de/fhemupdate/controls_fhem.txt: empty file received

rudolfkoenig

Danke fuer deine Recherche, ich habe das eingebaut, etwas getestet, und eingecheckt.
start_SSL sollte ab sofort HttpUtils_NonblockingGet nicht mehr blockieren.
Die anderen Zweige (http:// und BlockingGet) sollten nicht beruehrt sein.

knorxi

Suuuper! Vielen Dank!
Erste Tests sehen sehr gut aus.
Kein Freeze beim Connect.
Topp! Ich hoffe das hilft auch anderen, die eine Verbindung mit https aufbauen.

Bualicher

Hallo zusammen,
ich habe vorhin ein Update gemacht.
Danach kann ich nicht mehr auf FHEM zugreifen.
Im log vom Neustart steht Folgendes als letzter Eintrag:
Can't locate object method "connect_SSL" via package "IO::Socket::INET" at FHEM/HttpUtils.pm line 510.

Nachdem ich wieder die Vorgängerversion von HttpUtils.pm (25487) draufgemacht habe, läuft FHEM nach einem Neustart normal.

System läuft auf einem Pi (Buster).


Timmäää

#7
Genau das gleiche Problem habe ich auch und habe es im HMCCU-Thread gemeldet, da die Fehlermeldung zwischen vielen HMCCU-Events kam.
HMCCU scheint IO::Socket::INET zu nutzen, das ist aus der letzten Version von httpUtils aber hinausgeflogen in Zeile 6: " use IO::Socket::INET;"
Ggf. ist die Annahme aber auch falsch und es hat nichts mit HMCCU zu tun.

Ich habe mit auch zunächst geholfen, indem ich die alte httpUtils nutze.

rudolfkoenig

ZitatCan't locate object method "connect_SSL" via package "IO::Socket::INET" at FHEM/HttpUtils.pm line 510.
Ich gehe davon aus, dass eine alte Version von IO::Socket:SSL installiert ist.
Leider habe ich nicht rausgefunden, ab welcher Version connect_SSL unterstuetzt wird.
Ich habe jetzt eine Abfrage eingebaut: das nichtblockierende start_SSL wird nur dann gestartet, wenn connect_SSL vorhanden ist.
Waere nett, wenn ich dazu Feedback kriegen wuerde, da ich den Problemfall nicht getestet habe (s.o.).


ZitatHMCCU scheint IO::Socket::INET zu nutzen, das ist aus der letzten Version von httpUtils aber hinausgeflogen in Zeile 6: " use IO::Socket::INET;"
Verstehe die Aussage nicht.
IO::Socket::INET ist aus HttpUtils.pm seit eine Weile "rausgeflogen", weil das bereits in fhem.pl per use eingebunden wird.
Gibt es einen Grund, daran was zu aendern?

Timmäää

#9
ZitatVerstehe die Aussage nicht.
IO::Socket::INET ist aus HttpUtils.pm seit eine Weile "rausgeflogen", weil das bereits in fhem.pl per use eingebunden wird.
Gibt es einen Grund, daran was zu aendern?

Nein gibt es nicht, ich bin auch nicht derart versiert. Ich hatte nur gesehen, dass die Einbindung in httpUtils herausgenommen wurde und in der Fehlermeldung etwas zu diesem package steht. Vermutlich habe ich auch das SVN dafür falsch bedient, ich hatte die Zeile als rot gesehen und war vermeintlich bei jüngeren Änderungen.
Also bitte alles vergessen.

Danke fürs Fixen, ich benutzte das debian stretch Paket für libio-socket-ssl-perl, das muss dann alt sein.

Bualicher

Zitat von: rudolfkoenig am 03 Februar 2022, 10:23:58
...
Ich habe jetzt eine Abfrage eingebaut: das nichtblockierende start_SSL wird nur dann gestartet, wenn connect_SSL vorhanden ist.
Waere nett, wenn ich dazu Feedback kriegen wuerde, da ich den Problemfall nicht getestet habe (s.o.).
...

Habe deine Version 25622 aus dem Trunk versucht. Fehler bleibt leider bestehen.
Can't locate object method "connect_SSL" via package "IO::Socket::INET" at FHEM/HttpUtils.pm line 510.

JoWiemann

Hallo,

leider kommt 48_BlinkCamera.pm, auch mit den Änderungen von heute morgen, nicht klar.


2022.02.03 11:03:36 5: BlinkCamera_PollInfo BlinkSys: called
2022.02.03 11:03:36 4: BlinkCamera_DoCmd BlinkSys: called  for cmd :homescreen  par2:POLLING::
2022.02.03 11:03:36 4: BlinkCamera_DoCmd BlinkSys: try to send cmd homescreen  par2:POLLING:
2022.02.03 11:03:36 4: BlinkCamera_DoCmd BlinkSys: call url :https://rest-e004.immedia-semi.com/api/v3/accounts/163957/homescreen:
2022.02.03 11:03:36 4: BlinkCamera_PollInfo BlinkSys: initiate next polling homescreen 60s
2022.02.03 11:03:36 4: BlinkCamera_Callback BlinkSys: called from Polling
2022.02.03 11:03:36 4: BlinkCamera_Callback BlinkSys: status err ::  data <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML><HEAD><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<TITLE>ERROR: The request could not be satisfied</TITLE>
</HEAD><BODY>
<H1>400 ERROR</H1>
<H2>The request could not be satisfied.</H2>
<HR noshade size="1px">
Bad request.
We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner.
<BR clear="all">
If you provide content to customers through CloudFront, you can find steps to troubleshoot and help prevent this error by reviewing the CloudFront documentation.
<BR clear="all">
<HR noshade size="1px">
<PRE>
Generated by cloudfront (CloudFront)
Request ID: --- geschwärzt ---
</PRE>
<ADDRESS>
</ADDRESS>
</BODY></HTML>
2022.02.03 11:03:36 5: BlinkCamera_Callback BlinkSys: data returned :<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML><HEAD><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<TITLE>ERROR: The request could not be satisfied</TITLE>
</HEAD><BODY>
<H1>400 ERROR</H1>
<H2>The request could not be satisfied.</H2>
<HR noshade size="1px">
Bad request.
We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner.
<BR clear="all">
If you provide content to customers through CloudFront, you can find steps to troubleshoot and help prevent this error by reviewing the CloudFront documentation.
<BR clear="all">
<HR noshade size="1px">
<PRE>
Generated by cloudfront (CloudFront)
Request ID: - geschwärzt ---
</PRE>
<ADDRESS>
</ADDRESS>
</BODY></HTML>:
2022.02.03 11:03:36 4: BlinkCamera_Callback BlinkSys: after decoding status ret:Callback returned no valid JSON: malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "<!DOCTYPE HTML PUBLI...") at /opt/fhem/FHEM/48_BlinkCamera.pm line 1599.
:
2022.02.03 11:03:36 2: BlinkCamera_Callback BlinkSys: for cmd :homescreen:  retry :1  resulted in :Callback returned no valid JSON: malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "<!DOCTYPE HTML PUBLI...") at /opt/fhem/FHEM/48_BlinkCamera.pm line 1599.
:  cmdId :-- from Polling


Mehr debugging kann ich aus Zeitgründen heute nicht mehr machen.

Grüße Jörg
Jörg Wiemann

Slave: RPi B+ mit 512 MB, COC (868 MHz), CUL V3 (433.92MHz SlowRF); FHEMduino, Aktuelles FHEM

Master: CubieTruck; Debian; Aktuelles FHEM

rudolfkoenig

ZitatHabe deine Version 25622 aus dem Trunk versucht. Fehler bleibt leider bestehen.
Meine Theorie (IO::Socket::SSL ist alt) ist aus zwei Gruenden falsch: die Fehlermeldung redet von IO::Socket::INET, und die Meldung stammt aus der Zeile 510, der Aufruf in Zeile 498 ging ohne Probleme durch.
D.h. irgendwer aendert die Klasse von $hash->{conn} zwischen den beiden connect_SSL aufrufen.

Nach etwas experimentieren: das passiert, wenn der angesprochene Server kein HTTPS unterstuetzt.

Ich habe den Code erneut angepasst, und bitte um Feedback.

JoWiemann

Hallo Rudi,

anbei ein verbose 5 für 48_BlinkCamera.pm.


2022.02.03 12:16:36 5: DNS ANSWER 108:70728180000100040000000009726573742d653030340c696d6d656469612d73656d6903636f6d0000010001c00c000100010000003c00046c9d0404c00c000100010000003c00046c9d045dc00c000100010000003c00046c9d0455c00c000100010000003c00046c9d0433
2022.02.03 12:16:36 4: DNS result for rest-e004.immedia-semi.com: 108.157.4.4, ttl:60
2022.02.03 12:16:36 4: IP: rest-e004.immedia-semi.com -> 108.157.4.4
2022.02.03 12:16:36 5: HttpUtils request header:
GET /api/v3/accounts/163957/homescreen HTTP/1.0
Accept-Encoding: gzip,deflate
agent: TelegramBot/1.0
User-Agent: TelegramBot/1.0
Host: rest-e004.immedia-semi.com
token-auth: aScAZwjxhy1muOkosle0WA

2022.02.03 12:16:36 4: <hidden>: HTTP response code 400
2022.02.03 12:16:36 5: HttpUtils <hidden>: Got data, length: 915
2022.02.03 12:16:36 5: HttpUtils response header:
HTTP/1.1 400 Bad Request
Server: CloudFront
Date: Thu, 03 Feb 2022 11:16:36 GMT
Content-Type: text/html
Content-Length: 915
Connection: close
X-Cache: Error from cloudfront
Via: 1.1 c9ca35e5541827c5873bfdb59f015b20.cloudfront.net (CloudFront)
X-Amz-Cf-Pop: DUS51-P2
X-Amz-Cf-Id: gURqRK7hVuPina-s5F-Sc1bsUujiFkdsDalHMxEjV7HxAXvhHAAGIQ==
2022.02.03 12:16:36 4: BlinkCamera_Callback BlinkSys: called from DoCmd
2022.02.03 12:16:36 4: BlinkCamera_Callback BlinkSys: status err ::  data <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML><HEAD><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<TITLE>ERROR: The request could not be satisfied</TITLE>
</HEAD><BODY>
<H1>400 ERROR</H1>
<H2>The request could not be satisfied.</H2>
<HR noshade size="1px">
Bad request.
We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner.
<BR clear="all">
If you provide content to customers through CloudFront, you can find steps to troubleshoot and help prevent this error by reviewing the CloudFront documentation.
<BR clear="all">
<HR noshade size="1px">
<PRE>
Generated by cloudfront (CloudFront)
Request ID: --- geschwärzt ---
</PRE>
<ADDRESS>
</ADDRESS>
</BODY></HTML>
2022.02.03 12:16:36 5: BlinkCamera_Callback BlinkSys: data returned :<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML><HEAD><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<TITLE>ERROR: The request could not be satisfied</TITLE>
</HEAD><BODY>
<H1>400 ERROR</H1>
<H2>The request could not be satisfied.</H2>
<HR noshade size="1px">
Bad request.
We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner.
<BR clear="all">
If you provide content to customers through CloudFront, you can find steps to troubleshoot and help prevent this error by reviewing the CloudFront documentation.
<BR clear="all">
<HR noshade size="1px">
<PRE>
Generated by cloudfront (CloudFront)
Request ID: --- geschwärzt ---
</PRE>
<ADDRESS>
</ADDRESS>
</BODY></HTML>:
2022.02.03 12:16:36 4: BlinkCamera_Callback BlinkSys: after decoding status ret:Callback returned no valid JSON: malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "<!DOCTYPE HTML PUBLI...") at /opt/fhem/FHEM/48_BlinkCamera.pm line 1599.
:
2022.02.03 12:16:36 5: BlinkCamera_Callback BlinkSys: for cmd :homescreen:  retry :1  resulted in :Callback returned no valid JSON: malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "<!DOCTYPE HTML PUBLI...") at /opt/fhem/FHEM/48_BlinkCamera.pm line 1599.
:  cmdId :-- from DoCmd
2022.02.03 12:16:36 3: BlinkCamera_Callback BlinkSys: Reached max retries (ret: Callback returned no valid JSON: malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "<!DOCTYPE HTML PUBLI...") at /opt/fhem/FHEM/48_BlinkCamera.pm line 1599.
) for cmd homescreen
2022.02.03 12:16:36 5: Starting notify loop for BlinkSys, 5 event(s), first is cmdResult: Callback returned no valid JSON: malformed JSON string, neither tag, array, object, number, string or atom, at character offset 0 (before "<!DOCTYPE HTML PUBLI...") at /opt/fhem/FHEM/48_BlinkCamera.pm line 1599.\n
2022.02.03 12:16:36 5: Batterie: not on any display, ignoring notify
2022.02.03 12:16:36 5: End notify loop for BlinkSys
Jörg Wiemann

Slave: RPi B+ mit 512 MB, COC (868 MHz), CUL V3 (433.92MHz SlowRF); FHEMduino, Aktuelles FHEM

Master: CubieTruck; Debian; Aktuelles FHEM

Bualicher

Zitat von: rudolfkoenig am 03 Februar 2022, 12:03:44
...
Ich habe den Code erneut angepasst, und bitte um Feedback.

Super. Vielen Dank.
Funktioniert bei mir wieder mit Deiner Version 25623  :)

heinzfo

#15

knorxi

Bei mir ist jetzt doch noch auch ein Fehler aufgetreten.
Im Modul 98_DBPlan.pm (inoffizielles Modul für Fahrplanauskunft der Bahn) kamen "empty"-Pakete zurück.
Das Modul ruft im Callback rekursiv wieder HttpUtils_NonblockingGet mit dem selben Callback auf.
Das Modul funktioniert wieder, wenn ich vor dem Aufruf den alten Aufruf mit "HttpUtils_Close($hash);" schließe.
Könnte bei BlinkCamera ein ähnliches Problem vorliegen?
Zumindest deutet das darauf hin:
ZitatWe can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner.
Ist aber nur eine Vermutung :-\

JoWiemann

Zitat von: knorxi am 03 Februar 2022, 14:19:01

Könnte bei BlinkCamera ein ähnliches Problem vorliegen?
Zumindest deutet das darauf hin:Ist aber nur eine Vermutung :-\

Auf die Schnelle mal probiert. Hilft leider nicht.

Grüße Jörg
Jörg Wiemann

Slave: RPi B+ mit 512 MB, COC (868 MHz), CUL V3 (433.92MHz SlowRF); FHEMduino, Aktuelles FHEM

Master: CubieTruck; Debian; Aktuelles FHEM

rudolfkoenig


JoWiemann

Zitat von: rudolfkoenig am 03 Februar 2022, 14:53:53
Und wie schaut es mit der aktuellen HttpUtils.pm aus?

Hallo Rudi,

getestet mit: HttpUtils.pm 25623 2022-02-03 11:00:38Z rudolfkoenig

Grüße Jörg
Jörg Wiemann

Slave: RPi B+ mit 512 MB, COC (868 MHz), CUL V3 (433.92MHz SlowRF); FHEMduino, Aktuelles FHEM

Master: CubieTruck; Debian; Aktuelles FHEM

knorxi

ZitatUnd wie schaut es mit der aktuellen HttpUtils.pm aus?
98_DBPlan.pm benötigt auch mit der neuen Version ein HttpUtils_Close

Timmäää

Hi Rudi,

bei mir klappt es mit Rev 25623 wieder. Danke dir!

Gruß,
Timmäää

rudolfkoenig

Zitat98_DBPlan.pm benötigt auch mit der neuen Version ein HttpUtils_Close
Kannst mir bitte sagen, wie ich das reproduzien kann?

Zitatgetestet mit: HttpUtils.pm 25623 2022-02-03 11:00:38Z rudolfkoenig
Und? Funktioniert es wieder?
Wenn nicht: gibt es eine Moeglichkeit das Problem ohne Hardware nachzustellen?

rudolfkoenig

Habe eine neue Version eingecheckt: es behebt einen Bug bei der wiederholten Verwendung des gleichen Hashes bei nicht gesetzten keepalive Flag.

Bualicher

Mit der neuesten Version 25624 kann ich jetzt für meine Anwendungen keine Mängel mehr feststellen (WebGUI, TelegramBot, DoorBird).

Und irgendwie habe ich das Gefühl, dass FHEM um einiges schneller geworden ist. Kann natürlich auch täuschen  ;)

knorxi

Zitat von: rudolfkoenig am 03 Februar 2022, 20:36:23
Kannst mir bitte sagen, wie ich das reproduzien kann?
Habe 2 Dateien angehängt.
In 98_DBPlan.pm habe ich HttpUtils_Close hinzugefügt, dann funktioniert es.
In 98_DBPlan_ohne_close.pm funktioniert es mit den neuen HttpUtils (noch) nicht  ;).
define Bahn DBPlan 600 ;
attr Bahn dbplan-remote-timeout 10 ;
attr Bahn dbplan_destination Stuttgart Stadtmitte ;
attr Bahn dbplan_station Mettingen, Esslingen am Neckar

Mit set Bahn rereadDBInfo kannst du sehen, wie die Readings gefüllt werden (oder auch nicht).



Borkk

#26
Hallo Zusammen,

seit dem letzten Update, startet mein FHEM nicht mehr, bzw. es startet "im Kreis". Es läuft im DOCKER Container mit ConfigDB und die letzen LOG Einträge sehen wie folgt aus.

/entry.sh: line 621: kill: (5876) - No such process
Can't locate object method "connect_SSL" via package "IO::Socket::INET" at FHEM/HttpUtils.pm line 510.
Abrupt daemon termination, starting 10s countdown .../entry.sh: line 625: kill: (5876) - No such process
10/entry.sh: line 625: kill: (5876) - No such process
9/entry.sh: line 625: kill: (5876) - No such process
8/entry.sh: line 625: kill: (5876) - No such process
7/entry.sh: line 625: kill: (5876) - No such process
6/entry.sh: line 625: kill: (5876) - No such process
5/entry.sh: line 625: kill: (5876) - No such process
4/entry.sh: line 625: kill: (5876) - No such process
3/entry.sh: line 625: kill: (5876) - No such process
2/entry.sh: line 625: kill: (5876) - No such process
1/entry.sh: line 625: kill: (5876) - No such process
/entry.sh: line 632: kill: (5876) - No such process
0
Automatic restart ...


Die letzten Änderungen die ich an meinem FHEM gemacht habe, haben alle mit MQTT2 zu tun. Aber eigentlich lief alles soweit. Auf der Suche bin ich auf diesen Threat gestoßen und frage mich jetzt ob mein Problem evtl. damit zusammenhängt. Das mit den wenigen Angaben, keine Fehleranalyse möglich ist, ist mir bewusst. Ich hab nur aktuell keine Ahnung in welche Richtung ich suchen soll.

Ich habe noch einen 2. FHEM Docker Container laufen, der startet mit gleichem SW Stand ohne Probleme. Dort ist aber auch kein MQTT2 konfiguriert.
Docker@DS220+ FHEM, ConBeeII, Homebridge, Nginx ReverseProxy, ConfigDB, MQTT, NodeRed, InfluxDB, Grafana,
Raspberrymatic@Raspi3: HmIP Akt- /Sensoren, Shelly´s, Tibber Puls, Alexa, ASC, Gardena, Netatmo, E-Paper, FritzBox; Tado°, HOMEMODE, iBeacon, OLED ; ESP32/8266, SwitchBot ...

Borkk

#27
Ursache ist definitiv die HttpUtil.pm. von gestern. Mit der Version aus dem 6.1er Download startet alles ganz normal.
Docker@DS220+ FHEM, ConBeeII, Homebridge, Nginx ReverseProxy, ConfigDB, MQTT, NodeRed, InfluxDB, Grafana,
Raspberrymatic@Raspi3: HmIP Akt- /Sensoren, Shelly´s, Tibber Puls, Alexa, ASC, Gardena, Netatmo, E-Paper, FritzBox; Tado°, HOMEMODE, iBeacon, OLED ; ESP32/8266, SwitchBot ...

knorxi

@Borkk: Geht's mit der Version 25624 auch nicht? Oder hast du das überlesen?
Zitat von: Bualicher am 03 Februar 2022, 21:40:59
Mit der neuesten Version 25624 kann ich jetzt für meine Anwendungen keine Mängel mehr feststellen (WebGUI, TelegramBot, DoorBird).

Und irgendwie habe ich das Gefühl, dass FHEM um einiges schneller geworden ist. Kann natürlich auch täuschen  ;)

Borkk

Zitat von: knorxi am 04 Februar 2022, 08:45:10
@Borkk: Geht's mit der Version 25624 auch nicht? Oder hast du das überlesen?

Ich hatte das Problem mit der Version 25618 und bin dann erst mal auf eine sichere Version zurück um FHEM überhaupt wieder zu starten. Nach dem Update habe ich nun die Version 25624 und damit startet FHEM wieder. 

DANKE ;D
Docker@DS220+ FHEM, ConBeeII, Homebridge, Nginx ReverseProxy, ConfigDB, MQTT, NodeRed, InfluxDB, Grafana,
Raspberrymatic@Raspi3: HmIP Akt- /Sensoren, Shelly´s, Tibber Puls, Alexa, ASC, Gardena, Netatmo, E-Paper, FritzBox; Tado°, HOMEMODE, iBeacon, OLED ; ESP32/8266, SwitchBot ...

rudolfkoenig

ZitatIn 98_DBPlan_ohne_close.pm funktioniert es mit den neuen HttpUtils (noch) nicht  ;).
Bei mir schon.
Womoeglich ist unsere Definition von "neu" unterschiedlich, ich meine Version 25624 von gestern um 21:04.

knorxi

Sorry, es geht doch! ;D
War mir eigentlich sicher ich hätte die neuste Version benutzt. War wohl schon zu spät gestern  :-[
Nochmals vielen Dank und eine große Entschuldigung an alle, die dadurch in den letzten Tagen Probleme bekommen haben.
Ich denke aber, das Ergebnis kann sich wirklich sehen lassen und hilft allen.
Vielen Dank Rudolf! Wirklich top wie du das programmierst und dich einsetzt  :-*