मैं यह पता नहीं लगा सकता कि मेरे मैक पर lsof क्यों (10.8.2, मैकबुक प्रो) इतना धीमा है।
मेरे मैक पर, lsof
एक मिनट से अधिक समय लगता है:
$ touch /tmp/testfile
$ time lsof /tmp/testfile
real 1m16.483s
user 0m0.029s
sys 1m15.969s
एक विशिष्ट लिनक्स बॉक्स पर, Ubuntu 12.04 चल रहा है, lsof
20 एमएस लेता है:
$ touch /tmp/testfile
$ time lsof /tmp/testfile
real 0m0.023s
user 0m0.008s
sys 0m0.012s
समस्या तब बनी रहती है अगर मैं चला lsof -n
(DNS लुकअप से बचने के लिए)। इसके अलावा, मैंने जांचने की कोशिश की कि कौन से सिस्टम कॉल lsof
का उपयोग करके किया जाता है dtruss
, और पाया कि यह proc_info
दसियों बार कॉल कर रहा है:
$ sudo dtruss lsof /tmp/testfile 2> /tmp/dump
$ cat /tmp/dump | sort | uniq -c | sort -nr | head
10000 proc_info(0x2, 0x1199, 0x8) = 1272 0
6876 proc_info(0x2, 0x45, 0x8) = 1272 0
2360 proc_info(0x2, 0x190D, 0x8) = 1272 0
1294 proc_info(0x2, 0xFF, 0x8) = 1272 0
1152 proc_info(0x2, 0x474, 0x8) = 1272 0
1079 proc_info(0x2, 0x2F, 0x8) = 1272 0
709 proc_info(0x2, 0xFE, 0x8) = 1272 0
693 proc_info(0x2, 0x1F, 0x8) = 1272 0
623 proc_info(0x2, 0x11A, 0x8) = 1272 0
528 proc_info(0x2, 0xF7, 0x8) = 1272 0
कोई विचार? मैंने ये परीक्षण चलाए हैं और lsof
OS X (4.85) के साथ-साथ ftp ●sunsite.ualberta.ca/pub/Mirror/lsof/ (4.87) के नवीनतम संस्करण का उपयोग करते हुए एक ही परिणाम प्राप्त किया है ।
(जिज्ञासु के लिए, मैं इस प्रदर्शन से निराश हूं, इसका कारण यह है कि जब मैं छवियों को एवरनोट तक खींचता हूं, तो यह lsof
फ़ाइल को कॉपी करने की प्रक्रिया में चलता है, जिससे मेरा सिस्टम हर बार एक पूरे मिनट के लिए लटका रहता है जब मैं एक छवि सम्मिलित करने का प्रयास करता हूं (एवरनोट में।)
lsof
बिना किसी तर्क (सभी फाइलों को सूचीबद्ध करने के लिए) के साथ चलता हूं , तो यह एक मिनट के लिए लटका रहता है और फिर सभी फाइलों को प्रिंट करता है। लेकिन, जैसा कि मैंने उल्लेख किया है, यह अभी भी लटका हुआ है अगर मैं यह सूचीबद्ध करने की कोशिश करता हूं कि किसके पास / tmp निर्देशिका में एक एकल फ़ाइल खुली है, इसलिए यह एक विशेष खुली फ़ाइल नहीं है जो समस्या है। इसके अलावा, मैं कोई AirServer प्रक्रिया नहीं चला रहा हूं।
sudo opensnoop -n lsof
।
sudo opensnoop -n lsof
और lsof /tmp/testfile
दो टैब में, और ओपननोप ने केवल सूचना दी कि तीन फाइलें खोली गई थीं। तो समस्या अधिक संख्या में फ़ाइल खोलने की नहीं होनी चाहिए, लेकिन अत्यधिक proc_info
कॉल से संबंधित कुछ ।