इस सवाल के कई पहलू हैं जिन्हें आंशिक रूप से अन्य उपकरणों के माध्यम से संबोधित किया गया है, लेकिन एक भी उपकरण नहीं दिखता है जो उन सभी सुविधाओं को प्रदान करता है जिनकी आप तलाश कर रहे हैं।
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
CPU I के समय के लिए डिस्क I / O को छोड़कर प्रक्रियाओं के लिए नियमित करता है। आप इसे -a
स्विच का उपयोग करके आपको 30,000 फुट का दृश्य देने के लिए मनाना कर सकते हैं ताकि यह समय के साथ प्रक्रिया द्वारा संचय को दर्शाता है।
$ 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
फ्रेमवर्क एक्सेस की जा रही फाइलों के बारे में कोई विवरण प्रदान नहीं करता है। केवल एक्सेस का प्रकार, इसलिए इन उपकरणों का उपयोग करके डेटा की मात्रा के बारे में कोई जानकारी उपलब्ध नहीं है।
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
यह विकल्प बहुत निम्न स्तर का है। इसमें दृश्यता का अभाव है, जिसके कारण फ़ाइलें और / या इनोड एक्सेस किए जा रहे हैं, बस कच्चे ब्लॉक नंबर।
$ 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
यह लिनक्स कर्नेल और एक स्वागत योग्य के लिए एक नया अतिरिक्त है, इसलिए यह केवल नए डिस्ट्रोस जैसे कि उबंटू 12.10 में है। मेरे फेडोरा 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
उपरोक्त आपको उस प्रक्रिया आईडी को दिखाता है जो फ़ाइल एक्सेस कर रही है और यह किस फ़ाइल तक पहुंच रही है, लेकिन यह आपको कोई संपूर्ण बैंडविड्थ उपयोग नहीं देता है, इसलिए प्रत्येक एक्सेस किसी अन्य एक्सेस के लिए अप्रभेद्य है।
इसलिए क्या करना है?
fatrace
विकल्प शो के लिए सबसे वादा अंत में एक उपकरण है कि आप डिस्क की सकल उपयोग दिखा सकते हैं प्रदान करने आई / ओ एक्सेस किए जा रहे फ़ाइलें, बल्कि एक्सेस कर प्रक्रियाओं की तुलना के आधार पर।
संदर्भ