มีหลายแง่มุมสำหรับคำถามนี้ซึ่งได้รับการแก้ไขบางส่วนผ่านเครื่องมืออื่น ๆ แต่ดูเหมือนจะไม่เป็นเครื่องมือเดียวที่ให้คุณสมบัติทั้งหมดที่คุณต้องการ
iotop
เครื่องมือนี้แสดงให้เห็นว่ากระบวนการใดที่ใช้ I / O มากที่สุด แต่ไม่มีตัวเลือกในการแสดงชื่อไฟล์เฉพาะ
$ sudo iotop
Total DISK READ: 0.00 B/s | Total DISK WRITE: 0.00 B/s
TID PRIO USER DISK READ DISK WRITE SWAPIN IO> COMMAND
1 be/4 root 0.00 B/s 0.00 B/s 0.00 % 0.00 % init
2 be/4 root 0.00 B/s 0.00 B/s 0.00 % 0.00 % [kthreadd]
3 be/4 root 0.00 B/s 0.00 B/s 0.00 % 0.00 % [ksoftirqd/0]
5 be/4 root 0.00 B/s 0.00 B/s 0.00 % 0.00 % [kworker/u:0]
6 rt/4 root 0.00 B/s 0.00 B/s 0.00 % 0.00 % [migration/0]
7 rt/4 root 0.00 B/s 0.00 B/s 0.00 % 0.00 % [watchdog/0]
โดยค่าเริ่มต้นมันทำสิ่งที่ปกติtop
สำหรับกระบวนการ vying สำหรับเวลาของ CPU ยกเว้นดิสก์ I / O คุณสามารถเกลี้ยกล่อมเพื่อให้คุณได้รับมุมมอง 30,000 ฟุตโดยใช้-a
สวิตช์เพื่อให้แสดงการสะสมตามกระบวนการเมื่อเวลาผ่านไป
$ sudo iotop -a
Total DISK READ: 0.00 B/s | Total DISK WRITE: 0.00 B/s
TID PRIO USER DISK READ DISK WRITE SWAPIN IO> COMMAND
258 be/3 root 0.00 B 896.00 K 0.00 % 0.46 % [jbd2/dm-0-8]
22698 be/4 emma 0.00 B 72.00 K 0.00 % 0.00 % chrome
22712 be/4 emma 0.00 B 172.00 K 0.00 % 0.00 % chrome
1177 be/4 root 0.00 B 36.00 K 0.00 % 0.00 % cupsd -F
22711 be/4 emma 0.00 B 120.00 K 0.00 % 0.00 % chrome
22703 be/4 emma 0.00 B 32.00 K 0.00 % 0.00 % chrome
22722 be/4 emma 0.00 B 12.00 K 0.00 % 0.00 % chrome
เครื่องมือ i * (inotify, iwatch และอื่น ๆ )
เครื่องมือเหล่านี้จัดเตรียมการเข้าถึงเหตุการณ์การเข้าถึงไฟล์อย่างไรก็ตามพวกเขาจำเป็นต้องกำหนดเป้าหมายเป็นการเฉพาะไปยังไดเรกทอรีหรือไฟล์ที่ระบุ ดังนั้นจึงไม่เป็นประโยชน์เมื่อพยายามติดตามการเข้าถึงไฟล์โกงโดยกระบวนการที่ไม่รู้จักเมื่อแก้ไขข้อบกพร่องด้านประสิทธิภาพ
นอกจากนี้inotify
กรอบงานไม่ได้ให้รายละเอียดเกี่ยวกับไฟล์ที่กำลังเข้าถึง ประเภทการเข้าถึงเท่านั้นจึงไม่มีข้อมูลเกี่ยวกับปริมาณข้อมูลที่ถูกย้ายไปมาโดยใช้เครื่องมือเหล่านี้
iostat
แสดงประสิทธิภาพโดยรวม (อ่านและเขียน) ตามการเข้าถึงอุปกรณ์ที่กำหนด (ฮาร์ดไดรฟ์) หรือพาร์ติชัน แต่ไม่ได้ให้ข้อมูลเชิงลึกเกี่ยวกับไฟล์ที่กำลังสร้างการเข้าถึงเหล่านี้
$ iostat -htx 1 1
Linux 3.5.0-19-generic (manny) 08/18/2013 _x86_64_ (3 CPU)
08/18/2013 10:15:38 PM
avg-cpu: %user %nice %system %iowait %steal %idle
18.41 0.00 1.98 0.11 0.00 79.49
Device: rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await r_await w_await svctm %util
sda
0.01 0.67 0.09 0.87 1.45 16.27 37.06 0.01 10.92 11.86 10.82 5.02 0.48
dm-0
0.00 0.00 0.09 1.42 1.42 16.21 23.41 0.01 9.95 12.22 9.81 3.19 0.48
dm-1
0.00 0.00 0.00 0.02 0.01 0.06 8.00 0.00 175.77 24.68 204.11 1.43 0.00
blktrace
ตัวเลือกนี้อยู่ในระดับต่ำเกินไป มันขาดความสามารถในการมองเห็นว่าไฟล์ใดและ / หรือ inodes กำลังเข้าถึงอยู่แค่หมายเลขบล็อกดิบ
$ sudo blktrace -d /dev/sda -o - | blkparse -i -
8,5 0 1 0.000000000 258 A WBS 0 + 0 <- (252,0) 0
8,0 0 2 0.000001644 258 Q WBS [(null)]
8,0 0 3 0.000007636 258 G WBS [(null)]
8,0 0 4 0.000011344 258 I WBS [(null)]
8,5 2 1 1266874889.709032673 258 A WS 852117920 + 8 <- (252,0) 852115872
8,0 2 2 1266874889.709033751 258 A WS 852619680 + 8 <- (8,5) 852117920
8,0 2 3 1266874889.709034966 258 Q WS 852619680 + 8 [jbd2/dm-0-8]
8,0 2 4 1266874889.709043188 258 G WS 852619680 + 8 [jbd2/dm-0-8]
8,0 2 5 1266874889.709045444 258 P N [jbd2/dm-0-8]
8,0 2 6 1266874889.709051409 258 I WS 852619680 + 8 [jbd2/dm-0-8]
8,0 2 7 1266874889.709053080 258 U N [jbd2/dm-0-8] 1
8,0 2 8 1266874889.709056385 258 D WS 852619680 + 8 [jbd2/dm-0-8]
8,5 2 9 1266874889.709111456 258 A WS 482763752 + 8 <- (252,0) 482761704
...
^C
...
Total (8,0):
Reads Queued: 0, 0KiB Writes Queued: 7, 24KiB
Read Dispatches: 0, 0KiB Write Dispatches: 3, 24KiB
Reads Requeued: 0 Writes Requeued: 0
Reads Completed: 0, 0KiB Writes Completed: 5, 24KiB
Read Merges: 0, 0KiB Write Merges: 3, 12KiB
IO unplugs: 2 Timer unplugs: 0
Throughput (R/W): 0KiB/s / 510KiB/s
Events (8,0): 43 entries
Skips: 0 forward (0 - 0.0%)
fatrace
นี่เป็นส่วนเสริมใหม่ของเคอร์เนล Linux และเป็นที่ต้อนรับดังนั้นจึงเป็นเฉพาะใน distros รุ่นใหม่เช่น Ubuntu 12.10 ระบบ Fedora 14 ของฉันขาดไป 8-)
มันให้การเข้าถึงเดียวกับที่คุณสามารถผ่านได้inotify
โดยไม่ต้องกำหนดเป้าหมายไดเรกทอรีและ / หรือไฟล์
$ sudo fatrace
pickup(4910): O /var/spool/postfix/maildrop
pickup(4910): C /var/spool/postfix/maildrop
sshd(4927): CO /etc/group
sshd(4927): CO /etc/passwd
sshd(4927): RCO /var/log/lastlog
sshd(4927): CWO /var/log/wtmp
sshd(4927): CWO /var/log/lastlog
sshd(6808): RO /bin/dash
sshd(6808): RO /lib/x86_64-linux-gnu/ld-2.15.so
sh(6808): R /lib/x86_64-linux-gnu/ld-2.15.so
sh(6808): O /etc/ld.so.cache
sh(6808): O /lib/x86_64-linux-gnu/libc-2.15.so
ด้านบนแสดง ID กระบวนการที่ทำให้การเข้าถึงไฟล์และไฟล์ที่กำลังเข้าถึง แต่ไม่ให้การใช้แบนด์วิดท์โดยรวมสำหรับคุณดังนั้นการเข้าถึงแต่ละครั้งจะไม่สามารถแยกแยะการเข้าถึงอื่น ๆ ได้
แล้วจะทำอย่างไรดี?
fatrace
ตัวเลือกการแสดงสัญญามากที่สุดสำหรับFINALLYให้เครื่องมือที่สามารถแสดงให้คุณใช้งานของดิสก์รวม I / O ที่อยู่บนพื้นฐานของการเข้าถึงไฟล์มากกว่ากระบวนการทำเข้าถึงได้
อ้างอิง