Rumah > pembangunan bahagian belakang > Tutorial Python > Mengapa Bekas Docker Terpisah Saya Tidak Menunjukkan Output Cetakan Python?

Mengapa Bekas Docker Terpisah Saya Tidak Menunjukkan Output Cetakan Python?

Susan Sarandon
Lepaskan: 2024-11-23 04:32:20
asal
875 orang telah melayarinya

Why Doesn't My Detached Docker Container Show Python Print Output?

Bekas Docker Terpisah dan Output Cetakan dalam Aplikasi Python

Apabila menjalankan aplikasi Python (2.7) dalam bekas Docker terpisah (menggunakan bendera -d), pengguna mungkin menghadapi situasi di mana pernyataan cetakan aplikasi tidak menghasilkan sebarang output.

Memahami Output Python Penimbalan

Python menggunakan output penimbal secara lalai, bermakna ia menyimpan output dalam penimbal sebelum menghantarnya ke skrin. Dalam bekas tertanggal, penimbal ini mungkin tidak disiram dengan cukup kerap, menyebabkan ketiadaan output.

Menggunakan Output Tidak Penimbalan

Untuk menyelesaikan isu ini, output tidak penimbal boleh digunakan dengan -u bendera:

CMD ["python", "-u", "main.py"]
Salin selepas log masuk

Ini memastikan output ditulis ke skrin dengan serta-merta, tanpa mengira penimbalan tetapan.

Korelasi Log Docker

Dengan output tidak buffer, pernyataan cetakan akan kelihatan dalam log Docker:

docker logs myapp
> App started
Salin selepas log masuk

Gelagat Bekas Terpisah tanpa "-u"

Apabila bendera -u tidak digunakan, cetakan akan berkelakuan seperti berikut di dalam yang terpisah bekas:

  • Output disimpan dalam penimbal.
  • Jika penimbal menjadi penuh, ia disiram ke skrin.
  • Jika bekas keluar sebelum penimbal penuh, output hilang.

Menyahpepijat Petua

  • Gunakan bendera python -u: Uji aplikasi dengan output tidak penimbal di luar Docker untuk memastikan isu itu khusus kontena.
  • Semak log docker: Walaupun tanpa bendera -u, output harus kelihatan dalam log Docker, walaupun tertunda.
  • Lampirkan pada bekas: Melekat pada bekas dengan lampiran docker boleh memaparkan output jika penimbal cukup kecil untuk disiram sebelum ditanggalkan.

Atas ialah kandungan terperinci Mengapa Bekas Docker Terpisah Saya Tidak Menunjukkan Output Cetakan Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan