Eine meiner GAE-Aufgabenwarteschlangenanforderungen überschritt die Grenze für den weichen Speicher (Protokoll unten). Ich verstehe die Grenze für den weichen Speicher so, dass die Anforderung abgeschlossen wird und die Instanz anschließend beendet wird.GAE: Wird die Ausführung nach dem Überschreiten der Grenze für "Soft Private Memory" fortgesetzt?
Aus den Protokollen sieht es jedoch so aus, als wenn ich den Soft-Memory-Grenzwert erreiche, stoppt die Ausführung. Nach der Speicherlimitnachricht wird kein Protokollierungscode mehr angezeigt, und ich habe meinen Status überprüft, und es sieht nicht so aus, als ob die Anforderung abgeschlossen wird. Ich bin mir nicht sicher, ob es wichtig ist, aber diese Anforderung wird in einer TaskQueue der zurückgestellten Bibliothek ausgeführt.
Also, wenn eine TaskQueue ein Soft-Private-Memory-Limit erreicht, wird die Ausführung fortgesetzt, bis die Anfrage abgeschlossen ist oder sofort anhält? Ist es möglich, dass nur Logging-Code nicht mehr aufgezeichnet wird?
Log:
2012-04-11 23:45:13.203
Exceeded soft private memory limit with 145.848 MB after servicing 3 requests total
W 2012-04-11 23:45:13.203
After handling this request, the process that handled this request was found to be using too much memory and was terminated. This is likely to cause a new process to be used for the next request to your application. If you see this message frequently, you may have a memory leak in your application.
@speedplane gibt es ein Limit für die Protokollierung pro Anfrage, aber Sie sollten die letzten Protokolle in der Protokollanzeige –
+1 sehen, aber sind Sie sicher, dass die Instanz geschlossen ist sofort runter? Ich hatte meine Backend-Instanz für mehrere Male überschritten, und von dem, was ich beobachtet habe, konnte die Instanz Anfragen immer noch bedienen, bevor sie nach einer bestimmten Zeit abrupt heruntergefahren wurde. (Minuten, mindestens) –
Ja, da bin ich mir sicher. Schau dir das Protokoll an, das ich gerade gepostet habe. Es scheint abzustürzen, ohne dass überhaupt ein Protokollierungscode gedruckt wird. – speedplane