Getrennte Python-Container: Ungepufferte Ausgabe für die Protokollierung
Wenn Sie eine Python-Anwendung in einem getrennten Docker-Container mit dem Flag -d ausführen, können Sie dies tun Es kommt zu einem Mangel an Ausgabe aus dem Container. Obwohl der Container scheinbar läuft, sind die erwarteten Druckanweisungen der Anwendung nicht in den Protokollen oder über angeschlossene Terminalsitzungen sichtbar.
Das Problem liegt im Verhalten der Druckfunktion von Python. Standardmäßig puffert Python seine Ausgabe, um die Leistung zu verbessern. Diese Pufferung ist in interaktiven Shells nicht sofort sichtbar, wo die Ausgabe gedruckt wird, sobald ein Zeilenumbruchzeichen angetroffen wird.
Bei der Ausführung in einem getrennten Container wird die Ausgabe der Anwendung gepuffert und möglicherweise nicht sofort geleert. Um dieses Problem zu beheben, verwenden Sie die ungepufferte Ausgabe, indem Sie das Flag -u zum Python-Befehl im CMD der Docker-Datei hinzufügen:
CMD ["python", "-u", "main.py"]
Durch die Verwendung der ungepufferten Ausgabe werden die stdout- und stderr-Streams von Python sofort geleert, sodass die Protokolle erfasst werden können die print-Anweisungen. Sie können die Ausgabe dann anzeigen über:
docker logs myapp
Hinweis:
Das Flag -u erzwingt eine ungepufferte Ausgabe, was in einigen Fällen die Leistung beeinträchtigen kann. Wenn Sie das Ausgabepufferverhalten lieber manuell steuern möchten, sollten Sie die Verwendung des Protokollierungsmoduls in Betracht ziehen oder Ihre eigene Pufferlösung implementieren.
Das obige ist der detaillierte Inhalt vonWarum fehlt die Python-Ausgabe meines abgetrennten Docker-Containers und wie kann ich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!