เริ่มต้นด้วยการใช้เวลาตามคำแนะนำของ Jon Lin:
$ time ls test
test
real 0m0.004s
user 0m0.002s
sys 0m0.002s
คุณไม่ได้พูดถึงสิ่งที่สคริปต์ยูนิกซ์ของคุณทำงานอยู่ แต่ลองดูที่ linux, มัดมือบน Solaris / AIX, และฉันคิดว่า tusc บน hp-ux ให้คุณเรียนรู้มากมายเกี่ยวกับกระบวนการที่กำลังทำอยู่ ฉันชอบตัวเลือก -c ของ strace เพื่อรับบทสรุปที่ดี:
]$ strace -c ls
test
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
89.19 0.000998 998 1 execve
10.81 0.000121 121 1 write
0.00 0.000000 0 12 read
0.00 0.000000 0 93 79 open
0.00 0.000000 0 16 close
0.00 0.000000 0 2 1 access
0.00 0.000000 0 3 brk
0.00 0.000000 0 2 ioctl
0.00 0.000000 0 4 munmap
0.00 0.000000 0 1 uname
0.00 0.000000 0 6 mprotect
0.00 0.000000 0 2 rt_sigaction
0.00 0.000000 0 1 rt_sigprocmask
0.00 0.000000 0 1 getrlimit
0.00 0.000000 0 30 mmap2
0.00 0.000000 0 8 7 stat64
0.00 0.000000 0 13 fstat64
0.00 0.000000 0 2 getdents64
0.00 0.000000 0 1 fcntl64
0.00 0.000000 0 1 futex
0.00 0.000000 0 1 set_thread_area
0.00 0.000000 0 1 set_tid_address
0.00 0.000000 0 1 set_robust_list
0.00 0.000000 0 1 socket
0.00 0.000000 0 1 1 connect
------ ----------- ----------- --------- --------- ----------------
100.00 0.001119 205 88 total
โปรดทราบว่าการติดตั้งโปรแกรมประเภทการติดตามเหล่านี้อาจทำให้โปรแกรมช้าลงบ้าง