มีวิธีใดบ้างที่ฉันสามารถดูบันทึกของคอนเทนเนอร์ที่ออกไปแล้ว
ฉันสามารถรับ ID คอนเทนเนอร์ของคอนเทนเนอร์ที่ออกโดยใช้docker ps -a
แต่ฉันต้องการทราบว่าเกิดอะไรขึ้นเมื่อมันทำงาน
มีวิธีใดบ้างที่ฉันสามารถดูบันทึกของคอนเทนเนอร์ที่ออกไปแล้ว
ฉันสามารถรับ ID คอนเทนเนอร์ของคอนเทนเนอร์ที่ออกโดยใช้docker ps -a
แต่ฉันต้องการทราบว่าเกิดอะไรขึ้นเมื่อมันทำงาน
คำตอบ:
ใช้docker logs
. นอกจากนี้ยังใช้ได้กับคอนเทนเนอร์ที่หยุดและจับสตรีม STDOUT และ STDERR ทั้งหมดของกระบวนการหลักของคอนเทนเนอร์:
$ docker run -d --name test debian echo "Hello World"
02a279c37d5533ecde76976d7f9d1ca986b5e3ec03fac31a38e3dbed5ea65def
$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
49daa9d41a24 debian "echo test" 2 minutes ago Exited (0) 2 minutes ago test
$ docker logs -t test
2016-04-16T15:47:58.988748693Z Hello World
stack=s1 && c=$(task_id=$(docker stack ps "$stack" --filter desired-state=shutdown | tail -n +2 | head -n 1 | awk '{print $1}') && docker inspect --format '{{.Status.ContainerStatus.ContainerID}}' "$task_id") && docker logs "$c"
ชื่อสแต็กถูกระบุไว้ที่จุดเริ่มต้นของคำสั่ง
docker logs --tail=50 <container id>
สำหรับห้าสิบบรรทัดที่ผ่านมา - มีประโยชน์เมื่อคอนเทนเนอร์ของคุณทำงานเป็นเวลานาน
คุณสามารถใช้คำสั่งด้านล่างเพื่อคัดลอกบันทึกแม้กระทั่งจากคอนเทนเนอร์ที่ออก:
docker
cp
container_name:
path_of_file_in_container destination_path_locally
เช่น:
docker cp sravya:/tmp/report /root/mylog
ในการดูไฟล์บันทึกโดยตรงของคอนเทนเนอร์ที่ออกโดยใช้เวลาน้อยลงโดยเลื่อนไปที่ท้ายไฟล์ฉันใช้:
docker inspect $1 | grep 'LogPath' | sed -n "s/^.*\(\/var.*\)\",$/\1/p" | xargs sudo less +G
เรียกใช้เป็น. /viewLogs.sh CONTAINERNAME
วิธีนี้มีประโยชน์มากกว่า docker logs
วิธีการตามคือเปิดไฟล์โดยตรงแทนที่จะสตรีม
sudo เป็นสิ่งที่จำเป็นเนื่องจาก LogPath / File มักจะอยู่ภายใต้การเป็นเจ้าของรูท