วิธีการเรียกใช้ strace ในกระบวนการผู้ใช้สำหรับช่วงเวลาที่ระบุพูด 1 นาทีโดยไม่ต้องยกเลิกกระบวนการผู้ใช้และไม่ใช้ Ctrl + C?
ฉันต้องการสร้างสคริปต์เพื่อทำให้การดำเนินการสเตรซอัตโนมัติสำหรับกระบวนการผู้ใช้
วิธีการเรียกใช้ strace ในกระบวนการผู้ใช้สำหรับช่วงเวลาที่ระบุพูด 1 นาทีโดยไม่ต้องยกเลิกกระบวนการผู้ใช้และไม่ใช้ Ctrl + C?
ฉันต้องการสร้างสคริปต์เพื่อทำให้การดำเนินการสเตรซอัตโนมัติสำหรับกระบวนการผู้ใช้
คำตอบ:
ด้วยtimeout
ในGNU coreutils
คุณสามารถทำ:
timeout 60 strace -p PID
นี่คือตัวอย่าง
test.sh
:
#!/bin/bash
while :; do
echo "$$"
sleep 100
done
เรียกใช้:
$ ./test.sh
27121
ทำงานstrace
ด้วยtimeout
:
% cuonglm at ~
% timeout 60 strace -p 27121
Process 27121 attached - interrupt to quit
wait4(-1, [{WIFEXITED(s) && WEXITSTATUS(s) == 0}], 0, NULL) = 27311
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
--- SIGCHLD (Child exited) @ 0 (0) ---
wait4(-1, 0x7fff374b8598, WNOHANG, NULL) = -1 ECHILD (No child processes)
rt_sigreturn(0xffffffffffffffff) = 0
rt_sigaction(SIGINT, {0x45c4d0, [], SA_RESTORER, 0x7fcdc10e05c0}, {0x443910, [], SA_RESTORER, 0x7fcdc10e05c0}, 8) = 0
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
write(1, "27121\n", 6) = 6
rt_sigprocmask(SIG_BLOCK, [INT CHLD], [], 8) = 0
clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7fcdc1a699d0) = 27328
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigaction(SIGINT, {0x443910, [], SA_RESTORER, 0x7fcdc10e05c0}, {0x45c4d0, [], SA_RESTORER, 0x7fcdc10e05c0}, 8) = 0
wait4(-1,
หลังจาก 1 นาที:
....
rt_sigprocmask(SIG_BLOCK, [INT CHLD], [], 8) = 0
clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7fcdc1a699d0) = 27328
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigaction(SIGINT, {0x443910, [], SA_RESTORER, 0x7fcdc10e05c0}, {0x45c4d0, [], SA_RESTORER, 0x7fcdc10e05c0}, 8) = 0
wait4(-1, <unfinished ...>
Process 27121 detached
% cuonglm at ~
timeout
น่าจะเป็นคำตอบทั่วไป เพียงพิมพ์timeout 60s command
และคำสั่งจะสิ้นสุดใน 60 วินาที มันจะส่งTERM
ถ้าโปรแกรมทำงานโดยค่าเริ่มต้น คุณสามารถระบุสัญญาณที่คุณต้องการโดยใช้--signal
ตัวเลือก
ระยะเวลาสามารถตั้งค่าเป็นวินาทีนาทีชั่วโมงหรือวันโดยแต่ละช่วงเวลามีส่วนต่อท้ายเฉพาะเพื่อกำหนดสิ่งที่จะใช้