Rumah >pembangunan bahagian belakang >Tutorial Python >Mengapa Apl Python Saya Tidak Mencetak Apa-apa Apabila Dijalankan dalam Bekas Docker Terpisah?

Mengapa Apl Python Saya Tidak Mencetak Apa-apa Apabila Dijalankan dalam Bekas Docker Terpisah?

Patricia Arquette
Patricia Arquetteasal
2024-12-05 04:03:10776semak imbas

Why Doesn't My Python App Print Anything When Run in a Detached Docker Container?

Mengapa Apl Python Mencetak Tiada Apa-apa dalam Bekas Docker Tertanggal

Apabila melaksanakan apl Python dalam bekas Docker dalam mod tertanggal (-d flag), anda mungkin menghadapi masalah di mana output apl tidak boleh dilihat.

Reason

Fungsi "cetak" Python menggunakan output buffer, yang bermaksud output tidak serta-merta mengalir ke aliran stdout. Apabila berjalan dalam mod tertanggal, proses bekas keluar selepas skrip utama (main.py) melengkapkan gelungnya. Memandangkan penimbal stdout belum disiram lagi, output hilang.

Penyelesaian

Untuk menyelesaikan isu, dayakan output tidak penimbal menggunakan - u bendera dengan arahan Python dalam CMD Dockerfile arahan:

CMD ["python", "-u", "main.py"]

Dengan output tidak buffer, output apl akan ditulis dengan serta-merta kepada stdout, menjadikannya kelihatan apabila menggunakan log docker walaupun dalam mod terpisah:

$ docker run --name=myapp -d myappimage
> b82db1120fee5f92c80000f30f6bdc84e068bafa32738ab7adb47e641b19b4d1

$ docker logs myapp
> App started
> [loop output]

Atas ialah kandungan terperinci Mengapa Apl Python Saya Tidak Mencetak Apa-apa Apabila Dijalankan dalam Bekas Docker Terpisah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn