Path: csiph.com!fu-berlin.de!uni-berlin.de!individual.net!not-for-mail From: "Michael S." Newsgroups: de.comp.lang.python Subject: =?UTF-8?Q?Re:_[Python-de]_Micropython_-_Exception_nachtr=c3=a4glich?= =?UTF-8?Q?_ermitteln?= Date: Mon, 2 Jul 2018 15:57:59 +0200 Lines: 39 Message-ID: References: <9a003315-4f84-cadd-bc0e-2a6d025ab072@sschwarzer.net> Reply-To: michael_news2016@gmx.de Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit X-Trace: individual.net SPAEqMN1ch7UQPTGxc9KFwP0Rp5829JkW8EfaKdS5kpsmgr0iT Cancel-Lock: sha1:TMgiAxjlbLKB6AK4SG1dPyu7SsY= User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 In-Reply-To: Content-Language: de-DE Xref: csiph.com de.comp.lang.python:5198 Am 02.07.2018 um 15:30 schrieb Peter Heitzer: > Stefan Schwarzer wrote: >> On 2018-07-02 13:07, Michael S. wrote: >>> habe hier einen ESP8266 mit Micropython am Laufen. Der läuft 24h und >>> sendet zyklisch Daten an einen Webserver. Gelegentlich (Tage bis Wochen) >>> passiert es, das das Python-Script vermutlich mit einer Exception >>> abstürzt. Wenn ich dann mit WebREPL draufschaue sehe ich, dass die >>> Konsole funktional ist. >>> Das bedeutet: >>> 1. Es hat kein Reboot stattgefunden, denn dann wäre das >>> Script über den Autostart neu gestartet worden. >>> 2. Das Script wurde vermutlich durch eine Exception beendet. >>> >>> Die mir bekannten kritischen Dinge (Netzwerk) habe ich schon mit >>> Try/Except abgefangen. Trotzdem bricht das Skript ab. >>> >>> Wie bekomme ich raus, was das für eine Exception war? Ich kann schlecht >>> wochenlang ein Notebook mit RS232 durchlaufen lassen, um da mitzuhören. > >> ich habe keine Erfahrung mit MicroPython, aber sonst ist >> das übliche Vorgehen, auf der obersten Aufrufebene ein >> try/except zu verwenden und im Fehlerfall die Exception >> (evtl. mit weiteren Informationen) zu loggen. > > Wobei ich nicht weiss, wohin man im Falle eines Netzwerkfehler noch hin > loggen kann. Kann Micropython ins Flash des ESP8266 loggen? Ich kann Dateien im Flash speichern. Ich könnte bei einer Exception vermutlich ne Datei öffnen und dort die Daten der Exception reinschreiben. Solange z.B. RAM-Mangel nicht der Auslöser war, sollte das gehen. Tatsächlich muss ich auf dem Modul mit 10-20kB freiem RAM auskommen. Das waren aber nur Stichproben. Das freie RAM ändert sich ständig und schwankt. Keine Ahnung ob das auch mal auf Null fallen kann. -- Michael