如何解決docker logs無法實時輸出腳本打印的內(nèi)容
docker logs無法實時輸出腳本打印內(nèi)容
背景&問題
我在docker-compose.yml的command參數(shù)后面加入了一行運(yùn)行python腳本的命令:
command:python test.py
那么這條命令會在container生成的時候就開始運(yùn)行。
但是通過docker logs -f 命令來查看日志時,我發(fā)現(xiàn)py腳本里通過print打印出來的東西并不會實時顯示出來,而是程序執(zhí)行完了才會顯示出來,這并不是我想要的結(jié)果。
但如果進(jìn)入container手動執(zhí)行python腳本,就可以實時打印出來。
解決
在網(wǎng)上查找資料之后發(fā)現(xiàn),在這種情況下,python會默認(rèn)緩沖其輸出,所以想要無緩沖輸出,那么加一個“-u” 參數(shù)即可:
command: python -u test.py
這個時候再通過docker logs -f 來查看日志時,你就會看到實時打印出來的結(jié)果
問題解決!
docker logs不打印python程序輸出
docker logs --tail 50 --follow a8
即使容器在正常運(yùn)行,也不會有輸出打印出來,等也沒用,且不定時的會打印一兩次,最后才發(fā)現(xiàn),原來是python的IO有緩沖,stdout堵住了導(dǎo)致了
只需在python代碼中修改print(flush=True)即可,如果是用的gunicorn或者logging等,需要重新配置下
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
yum下載docker安裝包安裝到離線機(jī)器的實例代碼詳解
本文通過實例代碼給大家介紹了yum下載docker安裝包,安裝到離線機(jī)器,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12
騰訊云服務(wù)器docker開啟端口后無法訪問的解決方法
本文主要介紹了騰訊云服務(wù)器docker開啟端口后無法訪問的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
解決docker run中使用 ./ 相對路徑掛載文件或目錄失敗的問題
這篇文章主要介紹了解決docker run中使用‘./‘相對路徑掛載文件或目錄失敗的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03
docker入門教程(利用docker部署web應(yīng)用)
docker是一個用來裝應(yīng)用的容器,就像杯子可以裝水,筆筒可以放筆,書包可以放書,可以把hello word放在docker中,可以把網(wǎng)站放入docker中,可以把任何想得到的程序放在docker中,這篇文章主要介紹了docker入門(利用docker部署web應(yīng)用),需要的朋友可以參考下2023-02-02
使用Docker compose啟動自定義jar包的步驟詳解
這篇文章主要介紹了使用Docker compose啟動自定義jar包的步驟,首先我們需要編寫一個docker-compose.yml文件來定義我們的服務(wù)傳到我們的云服務(wù)器上,本文給大家分享示例代碼,感興趣的朋友一起看看吧2024-03-03

