NEWS
ioBroker friert ein: "Request actual repository...".....
-
@djmarc75 Sorry, dann habe ich die falsche Darstellung gewählt. Natürlich ist es ein Blockly:
<xml xmlns="https://developers.google.com/blockly/xml"> <variables> <variable id="0sMP]4h8G%L;e+hd;:J|">numberInstanzConnected</variable> <variable id="pAwkt}:^4Pi7YPKXTGH4">listWert</variable> <variable type="timeout" id="timeout2">timeout2</variable> <variable type="timeout" id="timeout">timeout</variable> </variables> <block type="comment" id="Jx6`69;o(.30WFP3kXmt" x="162" y="-413"> <field name="COMMENT">ermittelt Anzahl der verbundenen Instanzen und schreibt Wert in DP</field> <next> <block type="on_ext" id="}VB0XElJb.2BM9QxK8/}"> <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation> <field name="CONDITION">ne</field> <field name="ACK_CONDITION"></field> <value name="OID0"> <shadow type="field_oid" id="zJi=!?Kwz{CViZIAfYft"> <field name="oid">default</field> </shadow> <block type="selector" id="_01=ovj:|:~HnLoS_Gkb"> <field name="TEXT">state[id=system.*.*.*.*connected]</field> </block> </value> <statement name="STATEMENT"> <block type="procedures_callnoreturn" id="vr$6N*G;}`^9.kPJx@pl"> <mutation name="countInstanzConnected"></mutation> </block> </statement> </block> </next> </block> <block type="procedures_defnoreturn" id="KmT1LtI;Aa.OJU2ybgEh" x="163" y="-237"> <field name="NAME">countInstanzConnected</field> <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment> <statement name="STACK"> <block type="variables_set" id=",pNpcw)A5twc?hn(y4E("> <field name="VAR" id="0sMP]4h8G%L;e+hd;:J|">numberInstanzConnected</field> <value name="VALUE"> <block type="math_number" id="5#BQ@[!(GNJ!_6ach$Z7"> <field name="NUM">0</field> </block> </value> <next> <block type="controls_forEach" id="Ymgblw7x]]Nr0?.H4icU"> <field name="VAR" id="pAwkt}:^4Pi7YPKXTGH4">listWert</field> <value name="LIST"> <block type="selector" id="(IlvbxQm+0Ugx);HgzM|"> <field name="TEXT">state[id=system.*.*.*.*connected]</field> </block> </value> <statement name="DO"> <block type="controls_if" id="=!L7$NG+lw7Q%/fRb-+A"> <value name="IF0"> <block type="logic_compare" id="db`Sv[U#v5@wN(uleUX/"> <field name="OP">EQ</field> <value name="A"> <block type="get_value_var" id="$Bet4#W(`qj8i@1eE3:P"> <field name="ATTR">val</field> <value name="OID"> <shadow type="text" id="d@gto=uVA*(8uxSZG:Vx"> <field name="TEXT"></field> </shadow> <block type="variables_get" id="]@(Ij`EmXA1gDaD%!Vg]"> <field name="VAR" id="pAwkt}:^4Pi7YPKXTGH4">listWert</field> </block> </value> </block> </value> <value name="B"> <block type="logic_boolean" id="17dG-?_n1ca/EoUjSn[X"> <field name="BOOL">TRUE</field> </block> </value> </block> </value> <statement name="DO0"> <block type="math_change" id="dou[/X!2XtHyuTU9ZN+Z"> <field name="VAR" id="0sMP]4h8G%L;e+hd;:J|">numberInstanzConnected</field> <value name="DELTA"> <shadow type="math_number" id="m;o}zSNkreAqg:6na_Oa"> <field name="NUM">1</field> </shadow> <block type="math_number" id="!AcJDEEf{_?y,vcKAff*"> <field name="NUM">1</field> </block> </value> <next> <block type="debug" id="qp*,#O:t}8@|/-s3zZXz" disabled="true"> <field name="Severity">warn</field> <value name="TEXT"> <shadow type="text" id="VQnvxoop92S/5o_P=wh_"> <field name="TEXT">test</field> </shadow> <block type="get_value_var" id="*876w*rQNhI4FIsa[H}("> <field name="ATTR">val</field> <value name="OID"> <shadow type="text" id="[A*g]~HTz5MW:.W[SzQO"> <field name="TEXT"></field> </shadow> <block type="variables_get" id="EziRkFa!;%xydss*2^6q"> <field name="VAR" id="pAwkt}:^4Pi7YPKXTGH4">listWert</field> </block> </value> </block> </value> <next> <block type="update" id="(IkXj-95AM0d|u/Rj(3:"> <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation> <field name="OID">0_userdata.0.System.AnzahlInstanzenConnected</field> <field name="WITH_DELAY">FALSE</field> <value name="VALUE"> <block type="variables_get" id="O(;Ow0bAF!9|SJ+~)*``"> <field name="VAR" id="0sMP]4h8G%L;e+hd;:J|">numberInstanzConnected</field> </block> </value> </block> </next> </block> </next> </block> </statement> </block> </statement> </block> </next> </block> </statement> </block> <block type="comment" id="BY)7aa*12^m)L:zfqN1^" x="216" y="76"> <field name="COMMENT">prüft, ob eine Instanz nicht erreichbar ist</field> <next> <block type="comment" id="6)_C7[s{+BZ`j(O_$uL*"> <field name="COMMENT">Vorlage: https://www.machs-smart.de/iobroker-status-alive-connected-instanz-adapter-push-email/</field> <next> <block type="on_ext" id="?Q#4ffqYw~}cy,|wI|PF"> <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation> <field name="CONDITION">lt</field> <field name="ACK_CONDITION"></field> <value name="OID0"> <shadow type="field_oid" id="bSHTPdM,I)zz.I0i5;t)"> <field name="oid">default</field> </shadow> <block type="selector" id="^%WM-:8-TuX)Nbr{.W(h"> <field name="TEXT">state[id=system.*.*.*.*connected]</field> </block> </value> <statement name="STATEMENT"> <block type="timeouts_cleartimeout" id="Q#/@H4)RVPQ`Xc@tgkNA"> <field name="NAME">timeout</field> <next> <block type="timeouts_settimeout_variable" id="=6@BuLMG8-u^.^izs5en"> <field name="NAME">timeout</field> <value name="DELAY_MS"> <shadow type="math_number" id="11C.yn(?7EHNW5N@Wj*e"> <field name="NUM">20000</field> </shadow> </value> <statement name="STATEMENT"> <block type="controls_if" id="5c8k:m!aO}vw9Q4c_y@^"> <value name="IF0"> <block type="logic_negate" id="g@LEx?}=Ci-.;i9jro)*"> <value name="BOOL"> <block type="get_value_var" id="Ib$/aY5OL7l|71Z7cnDl"> <field name="ATTR">val</field> <value name="OID"> <shadow type="text" id="U9A4!hC||;*rz)ydl-+p"> <field name="TEXT"></field> </shadow> <block type="on_source" id=")8QNTcx%n]%YQ2h?%99*"> <field name="ATTR">id</field> </block> </value> </block> </value> </block> </value> <statement name="DO0"> <block type="update" id=",%x{]kt1R7HolH.+Kp#m"> <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation> <field name="OID">0_userdata.0.System.StatusInstanzen</field> <field name="WITH_DELAY">FALSE</field> <value name="VALUE"> <block type="logic_boolean" id="ZdHVphkb)lP63n6BD#Zn"> <field name="BOOL">FALSE</field> </block> </value> <next> <block type="telegram" id="!S!xfj,7!B?)hVp-64%:"> <field name="INSTANCE"></field> <field name="LOG"></field> <field name="SILENT">FALSE</field> <field name="PARSEMODE">default</field> <field name="ESCAPING">FALSE</field> <field name="DISABLE_WEB_PAGE_PREVIEW">FALSE</field> <value name="MESSAGE"> <shadow type="text" id="R];dOkU.y[2cGe0rWb8q"> <field name="TEXT">Passat Wohnzimmer 24Grad</field> </shadow> <block type="text_join" id="1ugKNeEU-3K9qrT@ZCv="> <mutation items="3"></mutation> <value name="ADD0"> <block type="text" id="]tD=(Z]2O;i~o00,N}Wt"> <field name="TEXT">ioBroker Instanz: </field> </block> </value> <value name="ADD1"> <block type="on_source" id="o^=s,]$0(?FU%03Y?Z.2"> <field name="ATTR">channelName</field> </block> </value> <value name="ADD2"> <block type="text" id="AlHL~VBS,U)D!^MG2{)o"> <field name="TEXT"> ist nicht erreichbar.</field> </block> </value> </block> </value> </block> </next> </block> </statement> </block> </statement> </block> </next> </block> </statement> </block> </next> </block> </next> </block> <block type="comment" id="[t=WW0lb4BP~dh2u6%LE" x="247" y="724"> <field name="COMMENT">Setzt Datenpunkt, wenn alle Instanzen wieder erreichbar sind</field> <next> <block type="on_ext" id="hdWeRo_R%rr9DU84ozg0"> <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation> <field name="CONDITION">gt</field> <field name="ACK_CONDITION"></field> <value name="OID0"> <shadow type="field_oid" id="2*lWyY-q6x3B+TaiFGb!"> <field name="oid">default</field> </shadow> <block type="selector" id="qI(L*MFb]#(uF7*BTFn:"> <field name="TEXT">state[id=system.*.*.*.*connected]</field> </block> </value> <statement name="STATEMENT"> <block type="timeouts_cleartimeout" id="`_RfunuRgSx,QX@$_e!z"> <field name="NAME">timeout</field> <next> <block type="timeouts_settimeout_variable" id="X]m7::y_-/TJ=0?,~h5o"> <field name="NAME">timeout2</field> <value name="DELAY_MS"> <shadow type="math_number" id="YI~c8[!dE4u]V|HG%qE%"> <field name="NUM">20000</field> </shadow> </value> <statement name="STATEMENT"> <block type="controls_if" id="kj4q4niol+3XN)mraxf_"> <value name="IF0"> <block type="get_value_var" id="L8ye$@4fB1-9Bz?.zbkN"> <field name="ATTR">val</field> <value name="OID"> <shadow type="text" id="FmJ/0XpCs]z-)U..+|-W"> <field name="TEXT"></field> </shadow> <block type="on_source" id="5g/Lcb3M)]D(PjpN1}R,"> <field name="ATTR">id</field> </block> </value> </block> </value> <statement name="DO0"> <block type="update" id="hW$27Y3?;N5:S-,d*6+/"> <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation> <field name="OID">0_userdata.0.System.StatusInstanzen</field> <field name="WITH_DELAY">FALSE</field> <value name="VALUE"> <block type="logic_boolean" id="8+J`^||kE6))e4UidYYl"> <field name="BOOL">TRUE</field> </block> </value> </block> </statement> </block> </statement> </block> </next> </block> </statement> </block> </next> </block> </xml>
-
@lollo_c sagte in ioBroker friert ein: "Request actual repository...".....:
Natürlich ist es ein Blockly
Man würde das gerne sehen ! XML ist wenig nützlich (am Handy und auch so)
Bitte einen Screenshot zeigen. -
@lollo_c
Warum 3 Trigger auf die gleichen States?
Das kann man alles in nur einem einzigen Trigger behandeln.Edit
... wobei das in JS tatsächlich einfacher und eleganter wärePrinzip:
const ids = Array.prototype.slice.apply($('state[id=system.*.*.*.connected]')); on({id: ids, change: 'ne'}, async function(obj) { let active = 0; let inactive = 0; for (let id of ids) { if (getState(id).val) { active++ } else { inactive++; } } log(`Aktive Instanzen: ${active}`); log(`Inaktive Instanzen: ${inactive}`); await setStateAsync('0_userdata.0.System.StatusInstanzen' , !inactive, true); });
-
leider kein Bild
könnt ihr was sehen, was durch das einlesen des Repos zu Problemen führt? -
@homoran sagte in ioBroker friert ein: "Request actual repository...".....:
was durch das einlesen des Repos zu Problemen führt?
nö, in dem Skript nicht - ist aber ein ziemlich (naja) Triggerlasstiges Skript.
Da wird 3 mal auf den gleichen DP getriggert und zusätzlich noch in einer Funktion.Ich versuch das grad mal irgendwie zu verstehn und umzubauen
-
@homoran
Krieg's nicht sauber importiert ... hab' kein Telegram. -
@homoran sagte in ioBroker friert ein: "Request actual repository...".....:
leider kein Bild
Sorry, ich musste das Bild erst zusammensetzen:
Ich hatte das Script so von machs-smart übernommen. Es hatte aber vor dem Neuaufsetzen und updaten des RasPi keine Probleme bereitet.
-
@lollo_c hast Du in Deiner Aufzählung auch Adapter die Scheduled sind ? z.B. Wetter oder so ?
-
@djmarc75 sagte in ioBroker friert ein: "Request actual repository...".....:
@lollo_c hast Du in Deiner Aufzählung auch Adapter die Scheduled sind ? z.B. Wetter oder so ?
Ja, hier die aktuelle iob diag:
-
@lollo_c sagte in ioBroker friert ein: "Request actual repository...".....:
Ja
Sehr gut dass du iob diag zeigst, aber wenn Du Scheduled-Adapter in Deiner Aufzählung hast dann kippt Dir Dein Skript um da diese Datenpunkte auf (null) gehen wenn der jeweilige Adapter sich wieder deaktiviert.
-
@djmarc75 sagte in ioBroker friert ein: "Request actual repository...".....:
... aber wenn Du Scheduled-Adapter in Deiner Aufzählung hast dann kippt Dir Dein Skript um da diese Datenpunkte auf (null) gehen wenn der jeweilige Adapter sich wieder deaktiviert.
So ganz verstehe ich das nicht, da die zeitgesteuerten Adapter den Datenpunkt "connection" nicht haben und deshalb von dem Script auch nicht angesprochen werden.
Wie dem auch sei, ich lasse das Script erst einmal deaktiviert und warte ab, was passiert.
-
@lollo_c sagte in ioBroker friert ein: "Request actual repository...".....:
da die zeitgesteuerten Adapter den Datenpunkt "connection" nicht haben
Aber klar hat jeder installierte Adapter den Datenpunkt "connected" - bis auf die VIS-Adapter, also Widgets-Adapter.
Ich bau da heut noch was zusammen. -
@djmarc75 sagte in ioBroker friert ein: "Request actual repository...".....:
Ich bau da heut noch was zusammen.
Als JS wäre es einfach:
const ids = Array.prototype.slice.apply($('state[id=system.*.*.*.connected]')); on({id: ids, change: 'ne'}, async function(obj) { let active = 0; let inactive = 0; for (let id of ids) { const instanceObject = await getObjectAsync(id.replace('.connected', '')); const scheduled = getAttr(instanceObject, 'common.schedule'); if (!scheduled) { if (getState(id).val) { active++ } else { inactive++; } } } log(`Aktive Instanzen: ${active}`); log(`Inaktive Instanzen: ${inactive}`); await setStateAsync('0_userdata.0.System.StatusInstanzen' , !inactive, true); });
Für Blockly fehlt mir gerade die Muße
-
Das Problem an diesem Script ist aber generell, dass man es regelmäßig neustarten muss damit alle Instanzen berücksichtigt werden. Und es könnte Probleme geben, wenn eine Instanz gelöscht wird (weil der State dann nicht mehr da ist, aber noch in der Liste steht).
@codierknecht sagte in ioBroker friert ein: "Request actual repository...".....:
getAttr(instanceObject, 'common.schedule');
Da würde ich eher auf den
common.mode
gehen und nurdaemon
berücksichtigen. Gibt ja neben Schedule auch noch einige andere. -
Wie gesagt:
@codierknecht sagte in ioBroker friert ein: "Request actual repository...".....:
Prinzip:
Da führen - wie so oft - viele Wege nach Rom.
@haus-automatisierung sagte in ioBroker friert ein: "Request actual repository...".....:
Das Problem an diesem Script ist aber generell, dass man es regelmäßig neustarten muss damit alle Instanzen berücksichtigt werden. Und es könnte Probleme geben, wenn eine Instanz gelöscht wird (weil der State dann nicht mehr da ist, aber noch in der Liste steht).
Das ließe sich vermutlich auch noch irgendwie automatisieren.
Ein bisschen Gehirnschmalz darf der TE da natürlich noch investieren -
@lollo_c Hallo Zusammen,
also an dem Script lag es offensichtlich nicht,. Obwohl es deaktiviert war hat der Raspi heute wieder seinen Dienst eingestellt: Symptome wie gehabt;- iobroker und Vis nicht erreichbar
- Raspi rote LED an, grüne blinkt,
- Ping antwortet sofort
- mit Putty nicht erreichbar.
Ich habe ihm eine Stunde Zeit gegeben und dann den Stecker gezogen. Nach dem Neustart ins Protokoll geschaut. Die letzten Einträge vor dem Crash waren wieder:
2024-03-12 15:44:10.246 - info: admin.0 (919) Request actual repository... 2024-03-12 15:44:12.765 - info: host.RasPi4 Updating repository "stable" under "http://download.iobroker.net/sources-dist.json"
Jemand eine Idee, wie ich weitersuchen kann?
-
@lollo_c sagte in ioBroker friert ein: "Request actual repository...".....:
Jemand eine Idee, wie ich weitersuchen kann?
Schau dir deine Lautsprecher-Skripte an. Nicht das du mit denen das System strangulierst.
-
@thomas-braun sagte in ioBroker friert ein: "Request actual repository...".....:
Schau dir deine Lautsprecher-Skripte an. Nicht das du mit denen das System strangulierst.
Okay, ich habe die Scripte erst einmal alle deaktiviert. Mal sehen, was morgen passiert
-
@lollo_c sagte in ioBroker friert ein: "Request actual repository...".....:
Okay, ich habe die Scripte erst einmal alle deaktiviert. Mal sehen, was morgen passiert
Gestern lief der ioBroker durch. Aber heute kam es wieder zum Absturz. Im Log waren um 16:51 Uhr wieder die letzten Meldungen zu lesen:
2024-03-14 16:51:44.443 - info: admin.0 (900) Adapter rating updated 2024-03-14 16:52:07.331 - info: admin.0 (900) Request actual repository... 2024-03-14 16:52:10.859 - info: host.RasPi4 Updating repository "stable" under "http://download.iobroker.net/sources-dist.json"
Danach wieder wie gehabt: ping i.O. ; mit Putty kein Zugriff. Um 17:41 habe ich dann den Stecker gezogen und der RasPi lief neu hoch. Beim betrachten der Logs fiel mir danach auf, dass der RasPi in der Zwischenzeit wohl doch was ins log geschrieben hat. Folgende Einträge sind von 17:31 Uhr:
2024-03-14 17:31:25.715 - info: host.RasPi4 iobroker.js-controller version 5.0.19 js-controller starting 2024-03-14 17:31:25.722 - info: host.RasPi4 Copyright (c) 2014-2023 bluefox, 2014 hobbyquaker 2024-03-14 17:31:25.723 - info: host.RasPi4 hostname: RasPi4, node: v18.19.1 2024-03-14 17:31:25.724 - info: host.RasPi4 ip addresses: 192.168.2.210 2003:e0:9712:9a00:a47e:4086:36a5:a208 fe80::5635:5d6e:3e15:cb7e 2024-03-14 17:31:27.258 - info: host.RasPi4 connected to Objects and States 2024-03-14 17:31:27.288 - info: host.RasPi4 added notifications configuration of host 2024-03-14 17:31:28.283 - info: host.RasPi4 Delete state "system.host.RasPi4.versions.nodeCurrent" 2024-03-14 17:31:28.287 - info: host.RasPi4 55 instances found 2024-03-14 17:31:28.368 - info: host.RasPi4 starting 28 instances 2024-03-14 17:31:28.381 - warn: host.RasPi4 startInstance cannot find adapter "vis-material-webfont@0.0.3". Try to install it... 1 attempt 2024-03-14 17:31:28.383 - info: host.RasPi4 iobroker install vis-material-webfont@0.0.3 using installedFrom 2024-03-14 17:31:28.572 - info: host.RasPi4 Delete state "system.host.RasPi4.versions.nodeNewest" 2024-03-14 17:31:28.591 - info: host.RasPi4 instance system.adapter.admin.0 started with pid 898 2024-03-14 17:31:28.623 - info: host.RasPi4 Delete state "system.host.RasPi4.versions.nodeNewestNext" 2024-03-14 17:31:28.633 - info: host.RasPi4 Delete state "system.host.RasPi4.versions.npmCurrent" 2024-03-14 17:31:28.641 - info: host.RasPi4 Delete state "system.host.RasPi4.versions.npmNewest" 2024-03-14 17:31:28.650 - info: host.RasPi4 Delete state "system.host.RasPi4.versions.npmNewestNext" 2024-03-14 17:31:28.658 - info: host.RasPi4 Some obsolete host states deleted. 2024-03-14 17:31:31.746 - error: host.RasPi4 iobroker npm-install: host.RasPi4 Unknown packetName vis-material-webfont. Please install packages from outside the repository using npm! 2024-03-14 17:31:32.513 - info: host.RasPi4 instance system.adapter.influxdb.0 started with pid 909 2024-03-14 17:31:32.803 - info: host.RasPi4 iobroker npm-install: exit 12 2024-03-14 17:31:32.957 - info: admin.0 (898) starting. Version 6.13.16 in /opt/iobroker/node_modules/iobroker.admin, node: v18.19.1, js-controller: 5.0.19 2024-03-14 17:31:33.009 - info: admin.0 (898) requesting all objects 2024-03-14 17:31:36.174 - info: admin.0 (898) received all objects 2024-03-14 17:31:36.561 - info: host.RasPi4 instance system.adapter.influxdb.1 started with pid 932 2024-03-14 17:31:36.754 - info: admin.0 (898) Request actual repository... 2024-03-14 17:31:36.826 - info: admin.0 (898) socket.io server listening on port 8081 2024-03-14 17:31:36.843 - info: admin.0 (898) http server listening on port 8081 2024-03-14 17:31:36.844 - info: admin.0 (898) Use link "http://127.0.0.1:8081" to configure. 2024-03-14 17:31:39.474 - info: influxdb.0 (909) starting. Version 4.0.2 in /opt/iobroker/node_modules/iobroker.influxdb, node: v18.19.1, js-controller: 5.0.19 2024-03-14 17:31:39.518 - info: influxdb.0 (909) No stored data from last exit found 2024-03-14 17:31:39.522 - info: influxdb.0 (909) Connecting http://localhost:8086/ ... 2024-03-14 17:31:39.523 - info: influxdb.0 (909) Influx DB Version used: 1.x
Dann folgt eine ganze Auflistung bei der alle geloggten Datenpunkte der influxdb aufgelistet sind. Gefolgt von eine Auflistung aller Scripte im javascript-Adapter und dann den Homematic usw. Adapter.
Würde mich über den nächsten Tipp zur Fehlersuche sehr freuen. -
@lollo_c sagte in ioBroker friert ein: "Request actual repository...".....:
Folgende Einträge sind von 17:31 Uhr:
nicht unbedingt!
der Raspi hat keine Batteriegepufferte Echtzeituhr.
es kann also eine falsche Uhrzeit sein, bevorcder Pi sich per ntp wieder die richtige Zeit verschaffen konnte.