Rumah >pembangunan bahagian belakang >Tutorial Python >Mengapa Apl Python Saya Tidak Mencetak Apa-apa Apabila Dijalankan dalam Bekas Docker Terpisah?
Apabila melaksanakan apl Python dalam bekas Docker dalam mod tertanggal (-d flag), anda mungkin menghadapi masalah di mana output apl tidak boleh dilihat.
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.
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!