हर निर्देशिका का आकार 4096 बाइट्स (4 K) क्यों होता है?


33

जैसा कि विषय कहता है; मैं जानना चाहता हूं कि प्रत्येक निर्देशिका का आकार 4K के बराबर क्यों होता है, भले ही उनके पास 4K से अधिक आकार वाली फाइलें हों।

कृपया निम्नलिखित पर एक नज़र डालें: -

$ ls -lh
total 2.0M
drwxr-xr-x 4 ankit ankit 4.0K Sep 11 07:28 Desktop

$ ls -lrh Desktop/
-rw-rw-r-- 1 ankit ankit 9.1M Aug 4 11:15 sophosthreatsaurusaz.pdf
-rw------- 1 ankit ankit 107K Dec 27 2010 KP 3 0.pdf
drwxrwsr-x 9 ankit ankit 4.0K Sep 10 19:26 eclipse

पुनश्च: मुझे du -shकमांड लाइन उपयोगिता के बारे में पता है ।

संपादित करें: मैं निर्देशिका को फ़ाइलों के लिए एक कंटेनर के रूप में मान रहा हूं।


यह डायरेक्टरी का मेटा-डेटा है
टैकींस

जवाबों:


34
  • बहुत अधिक तकनीकी होने के बिना, एक निर्देशिका प्रविष्टि के बारे में सोचें, जिसमें निर्देशिका "फाइलों " की एक सूची के लिए "लिंक" है ।
  • फिर, जैसा कि सब कुछ है, lsआपको उस लिंक का आकार दिखाता है, निर्देशिका की सामग्री द्वारा कब्जा किए गए कुल स्थान को नहीं।
  • फ़ाइल या निर्देशिका प्रविष्टि / लिंक का न्यूनतम आकार एक ब्लॉक होना चाहिए, जो आमतौर पर अधिकांश एक्स 3/4 फाइल सिस्टम पर 4096 बाइट्स / 4K होता है।

7
आप कहते हैं कि "न्यूनतम आकार एक फ़ाइल या निर्देशिका प्रविष्टि / लिंक पर कब्जा होना चाहिए एक ब्लॉक है" लेकिन मुझे यकीन है कि मैंने फ़ाइल का आकार 4K से कम देखा है।
Lakshay Garg

1
@LakshayGarg हालांकि फ़ाइल 4K से कम हो सकती है, फिर इसका कारण "आंतरिक विखंडन" होगा, जहां छोटी फ़ाइल को संग्रहीत करने के लिए ब्लॉक के कुछ बाइट्स का उपयोग किया गया है।
फिलाफ्लाश

@phyloflash कुछ फाइल सिस्टम (जैसे NTFS) फ़ाइल प्रविष्टियों में छोटी फ़ाइलों को स्वयं संग्रहीत करता है (NTFS के लिए यह एमएफटी प्रविष्टि में है)। इस तरह उनकी सामग्री शून्य आवंटन ब्लॉकों पर कब्जा कर लेती है, और आंतरिक विखंडन कम हो जाता है।
रुस्लान

26

इसे समझने के लिए, आपको निम्नलिखित (फाइल सिस्टम) का कुछ बुनियादी ज्ञान होगा:

  • इनकोड (फ़ाइल विशेषताएँ, फ़ाइल का मेटाडेटा, पॉइंटर संरचना)
  • फ़ाइल (2 स्तंभों के साथ एक तालिका मानी जा सकती है, फ़ाइल नाम और इसके इनकोड, ब्लॉक यूनिट पर कच्चे डेटा ब्लॉक के लिए इनकोड पॉइंट्स)
  • निर्देशिका (बस एक विशेष फ़ाइल, अन्य फ़ाइलनामों के लिए कंटेनर। इसमें फ़ाइल नाम के लिए फ़ाइल नाम और इनकोड संख्याओं की एक सरणी होती है। इसके अलावा यह माता-पिता और बच्चों के बीच संबंध का वर्णन करता है।)
  • प्रतीकात्मक लिंक VS हार्ड लिंक
  • डेंट्री (निर्देशिका प्रविष्टियाँ)
  • ...

विशिष्ट ext4फ़ाइल सिस्टम (अधिकांश लोग क्या उपयोग करते हैं) पर, डिफ़ॉल्ट inodeआकार 256 बाइट्स है, ब्लॉक आकार 4096 बाइट्स है।

एक निर्देशिका सिर्फ एक विशेष फ़ाइल है जिसमें फ़ाइल नाम और इनोड संख्या की एक सरणी होती है। जब निर्देशिका बनाई गई थी, तो फ़ाइल सिस्टम ने निर्देशिका को "फ़ाइल नाम" (वास्तव में डायर नाम) के साथ 1 इनोड आवंटित किया था। इनोड एक एकल डेटा ब्लॉक (न्यूनतम ओवरहेड) को इंगित करता है, जो कि 4096 बाइट्स है। इसीलिए उपयोग करते समय आप 4096 / 4.0K देखें ls

आप tune2fs& का उपयोग करके विवरण प्राप्त कर सकते हैं dumpe2fs

उदाहरण

root@ubuntu:~# tune2fs -l /dev/ubuntu/root 
tune2fs 1.42 (29-Nov-2011)
Filesystem volume name:   <none>
Last mounted on:          /
Filesystem UUID:          2fca4cbb-22f1-4328-ab13-cacedb360930
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      has_journal ext_attr resize_inode dir_index filetype needs_recovery extent flex_bg sparse_super large_file huge_file uninit_bg dir_nlink extra_isize
Filesystem flags:         signed_directory_hash 
Default mount options:    user_xattr acl
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              967680
Block count:              3931136
Reserved block count:     0
Free blocks:              2537341
Free inodes:              517736
First block:              0
Block size:               4096
Fragment size:            4096
Reserved GDT blocks:      416
Blocks per group:         32768
Fragments per group:      32768
Inodes per group:         8064
Inode blocks per group:   504
RAID stride:              35637
Flex block group size:    16
Filesystem created:       Thu Mar 15 14:31:04 2012
Last mount time:          Sat Oct 20 20:28:04 2012
Last write time:          Sat Oct 20 20:23:32 2012
Mount count:              1
Maximum mount count:      -1
Last checked:             Sat Oct 20 20:22:57 2012
Check interval:           0 (<none>)
Lifetime writes:          54 GB
Reserved blocks uid:      0 (user root)
Reserved blocks gid:      0 (group root)
First inode:              11
Inode size:           256
Required extra isize:     28
Desired extra isize:      28
Journal inode:            8
First orphan inode:       272350
Default directory hash:   half_md4
Directory Hash Seed:      d582ad79-75a0-4964-9a48-33ddba04df5c
Journal backup:           inode blocks

7

यदि किसी फ़ाइल में कोई डेटा होता है (यहां तक ​​कि एक भी बाइट), तो यह डिस्क पर एक ब्लॉक पर कब्जा कर लेगा (जो आमतौर पर इन दिनों 4k है)। फ़ाइलों के बीच एक ब्लॉक साझा नहीं किया जा सकता है। इसका मतलब है कि उस पूरे ब्लॉक का स्थान अन्य फ़ाइलों के लिए उपलब्ध नहीं होगा, इसलिए इसे "उपयोग" माना जाता है।

स्रोत

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.