ఇనోడ్ గురించి కొంత

క్రమానుగతంగా, సెంట్రల్ డిస్ట్రిబ్యూషన్ సెంటర్‌కి వెళ్లడానికి, నేను DevOps స్థానం కోసం ప్రధానంగా సెయింట్ పీటర్స్‌బర్గ్ మరియు మాస్కోలో వివిధ పెద్ద కంపెనీలలో ఇంటర్వ్యూ చేస్తాను. చాలా కంపెనీలు (చాలా మంచి కంపెనీలు, ఉదాహరణకు Yandex) ఇలాంటి రెండు ప్రశ్నలను అడగడం నేను గమనించాను:

  • ఇనోడ్ అంటే ఏమిటి;
  • ఏ కారణాల వల్ల మీరు డిస్క్ రైట్ ఎర్రర్‌ను పొందవచ్చు (లేదా ఉదాహరణకు: మీ డిస్క్ స్థలం ఎందుకు అయిపోవచ్చు, సారాంశం అదే).

తరచుగా జరిగేటట్లుగా, ఈ విషయం నాకు బాగా తెలుసునని నేను ఖచ్చితంగా అనుకుంటున్నాను, కానీ నేను వివరించడం ప్రారంభించిన వెంటనే, జ్ఞానంలో ఖాళీలు స్పష్టంగా కనిపించాయి. నా జ్ఞానాన్ని క్రమబద్ధీకరించడానికి, ఖాళీలను పూరించడానికి మరియు ఇకపై నన్ను ఇబ్బంది పెట్టకుండా, నేను ఈ కథనాన్ని వ్రాస్తున్నాను, బహుశా అది మరొకరికి ఉపయోగకరంగా ఉంటుంది.

నేను దిగువ నుండి ప్రారంభిస్తాను, అనగా. హార్డ్ డ్రైవ్ నుండి (మేము ఫ్లాష్ డ్రైవ్‌లు, SSDలు మరియు ఇతర ఆధునిక విషయాలను విస్మరిస్తాము; ఉదాహరణకు, బ్లాక్ పరిమాణం 20 బైట్లు ఉన్నందున, ఏదైనా 80 లేదా 512 గిగ్ పాత డ్రైవ్‌ని పరిశీలిద్దాం).

హార్డ్ డ్రైవ్‌కు బైట్ ద్వారా దాని స్పేస్ బైట్‌ను ఎలా పరిష్కరించాలో తెలియదు; ఇది షరతులతో బ్లాక్‌లుగా విభజించబడింది. బ్లాక్ నంబరింగ్ 0 నుండి ప్రారంభమవుతుంది. (దీనిని LBA అంటారు, వివరాలు ఇక్కడ ఉన్నాయి: ru.wikipedia.org/wiki/LBA)

ఇనోడ్ గురించి కొంత

బొమ్మ నుండి చూడగలిగినట్లుగా, నేను LBA బ్లాక్‌లను HDD స్థాయిగా నియమించాను. మార్గం ద్వారా, మీ డిస్క్‌లో ఏ బ్లాక్ సైజు ఉందో మీరు చూడవచ్చు:

root@ubuntu:/home/serp# blockdev --getpbsz /dev/sdb
512

పై స్థాయి ఒక విభజన, ఇది మొత్తం డిస్క్‌కి ఒకటి (మళ్ళీ సరళత కోసం). చాలా తరచుగా, రెండు రకాల విభజన మార్కప్ ఉపయోగించబడుతుంది: msdos మరియు gpt. దీని ప్రకారం, msdos అనేది 2Tb వరకు డిస్క్‌లకు మద్దతు ఇచ్చే పాత ఫార్మాట్, gpt అనేది 1 బైట్ బ్లాక్‌లలో 512 జెటాబైట్ వరకు అడ్రస్ చేయగల కొత్త ఫార్మాట్. మా విషయంలో, మేము msdos రకం విభజనను కలిగి ఉన్నాము, ఫిగర్ నుండి చూడవచ్చు, విభజన బ్లాక్ నంబర్ 1తో ప్రారంభమవుతుంది, అయితే MBR కోసం సున్నా ఉపయోగించబడుతుంది.

మొదటి విభజనలో నేను ext2 ఫైల్ సిస్టమ్‌ను సృష్టించాను, దాని డిఫాల్ట్ బ్లాక్ పరిమాణం 4096 బైట్లు, ఇది చిత్రంలో కూడా ప్రతిబింబిస్తుంది. మీరు ఫైల్ సిస్టమ్ బ్లాక్ పరిమాణాన్ని ఇలా చూడవచ్చు:

root@ubuntu:/home/serp# tune2fs -l /dev/sdb1
tune2fs 1.42.9 (4-Feb-2014)
Filesystem volume name:   <none>
Last mounted on:          <not available>
Filesystem UUID:          a600bf40-f660-41f6-a3e6-96c303995479
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      ext_attr resize_inode dir_index filetype sparse_super large_file
Filesystem flags:         signed_directory_hash
Default mount options:    user_xattr acl
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              65536
Block count:              261888
Reserved block count:     13094
Free blocks:              257445
Free inodes:              65525
First block:              0
Block size:               4096
Fragment size:            4096
Reserved GDT blocks:      63
Blocks per group:         32768
Fragments per group:      32768
Inodes per group:         8192
Inode blocks per group:   512
Filesystem created:       Fri Aug  2 15:02:13 2019
Last mount time:          n/a
Last write time:          Fri Aug  2 15:02:14 2019
Mount count:              0
Maximum mount count:      -1
Last checked:             Fri Aug  2 15:02:13 2019
Check interval:           0 (<none>)
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
Default directory hash:   half_md4
Directory Hash Seed:      c0155456-ad7d-421f-afd1-c898746ccd76

మనకు అవసరమైన పరామితి "బ్లాక్ పరిమాణం".

ఇప్పుడు ఆసక్తికరమైన విషయం ఏమిటంటే /home/serp/testfile ఫైల్‌ని ఎలా చదవాలి? ఒక ఫైల్ దాని డేటా నిల్వ చేయబడిన ఒకటి లేదా అంతకంటే ఎక్కువ ఫైల్ సిస్టమ్ బ్లాక్‌లను కలిగి ఉంటుంది. ఫైల్ పేరు తెలుసుకోవడం, దాన్ని ఎలా కనుగొనాలి? నేను ఏ బ్లాకులను చదవాలి?

ఇక్కడే ఐనోడ్స్ ఉపయోగపడతాయి. ext2fs ఫైల్ సిస్టమ్ అన్ని ఐనోడ్‌ల కోసం సమాచారాన్ని కలిగి ఉన్న "టేబుల్"ని కలిగి ఉంది. ఫైల్ సిస్టమ్‌ను సృష్టించేటప్పుడు ext2fs విషయంలో ఐనోడ్‌ల సంఖ్య సెట్ చేయబడుతుంది. మేము tune2fs అవుట్‌పుట్ యొక్క "ఇనోడ్ కౌంట్" పరామితిలో అవసరమైన సంఖ్యలను చూస్తాము, అనగా. మా వద్ద 65536 ముక్కలు ఉన్నాయి. ఐనోడ్ మనకు అవసరమైన సమాచారాన్ని కలిగి ఉంది: మనం వెతుకుతున్న ఫైల్ కోసం ఫైల్ సిస్టమ్ బ్లాక్‌ల జాబితా. ఇచ్చిన ఫైల్ కోసం ఐనోడ్ సంఖ్యను ఎలా కనుగొనాలి?

సంబంధిత పేరు మరియు ఐనోడ్ సంఖ్య డైరెక్టరీలో ఉంటాయి మరియు ext2fsలోని డైరెక్టరీ ఒక ప్రత్యేక రకం ఫైల్, అనగా. దాని స్వంత ఐనోడ్ సంఖ్య కూడా ఉంది. ఈ విష వృత్తాన్ని విచ్ఛిన్నం చేయడానికి, రూట్ డైరెక్టరీకి “ఫిక్స్‌డ్” ఐనోడ్ నంబర్ “2” కేటాయించబడింది. ఐనోడ్ సంఖ్య 2లోని విషయాలను చూద్దాం:

root@ubuntu:/# debugfs /dev/sdb1
debugfs 1.42.9 (4-Feb-2014)
debugfs:  stat <2>

Inode: 2   Type: directory    Mode:  0755   Flags: 0x0
Generation: 0    Version: 0x00000000:00000002
User:     0   Group:     0   Size: 4096
File ACL: 0    Directory ACL: 0
Links: 3   Blockcount: 8
Fragment:  Address: 0    Number: 0    Size: 0
 ctime: 0x5d43cb51:16b61bcc -- Fri Aug  2 16:34:09 2019
 atime: 0x5d43c247:b704301c -- Fri Aug  2 15:55:35 2019
 mtime: 0x5d43cb51:16b61bcc -- Fri Aug  2 16:34:09 2019
crtime: 0x5d43b5c6:00000000 -- Fri Aug  2 15:02:14 2019
Size of extra inode fields: 28
BLOCKS:
(0):579
TOTAL: 1

మీరు చూడగలిగినట్లుగా, మనకు అవసరమైన డైరెక్టరీ బ్లాక్ నంబర్ 579లో ఉంది. అందులో హోమ్ ఫోల్డర్ కోసం నోడ్ నంబర్‌ను కనుగొంటాము మరియు సెర్ప్ డైరెక్టరీలో మేము అభ్యర్థించిన ఫైల్ కోసం నోడ్ నంబర్‌ను చూసే వరకు గొలుసును చూస్తాము. అకస్మాత్తుగా ఎవరైనా నంబర్ సరైనదేనా మరియు అవసరమైన సమాచారం ఉందా లేదా అని తనిఖీ చేయాలనుకుంటే, అది కష్టం కాదు. మేము చేస్తాము:

root@ubuntu:/# dd if=/dev/sdb1 of=/home/serp/dd_image bs=4096 count=1 skip=579
1+0 records in
1+0 records out
4096 bytes (4,1 kB) copied, 0,000184088 s, 22,3 MB/s
root@ubuntu:/# hexdump -c /home/serp/dd_image

అవుట్‌పుట్‌లో మీరు డైరెక్టరీలోని ఫైల్‌ల పేర్లను చదవవచ్చు.

కాబట్టి నేను ప్రధాన ప్రశ్నకు వచ్చాను: “ఏ కారణాల వల్ల రికార్డింగ్ లోపం సంభవించవచ్చు?”

సహజంగానే, ఫైల్ సిస్టమ్‌లో ఉచిత బ్లాక్‌లు లేనట్లయితే ఇది జరుగుతుంది. ఈ సందర్భంలో ఏమి చేయవచ్చు? స్పష్టమైన “అనవసరమైన ఏదైనా తొలగించు” కాకుండా, ext2,3 మరియు 4 ఫైల్ సిస్టమ్‌లలో “రిజర్వ్డ్ బ్లాక్ కౌంట్” వంటి విషయం ఉందని మీరు గుర్తుంచుకోవాలి. మీరు ఎగువ జాబితాను చూస్తే, మా వద్ద "13094" అటువంటి బ్లాక్‌లు ఉన్నాయి. ఇవి రూట్ యూజర్ మాత్రమే వ్రాయగలిగే బ్లాక్‌లు. కానీ మీరు సమస్యను త్వరగా పరిష్కరించాల్సిన అవసరం ఉంటే, తాత్కాలిక పరిష్కారంగా మీరు వాటిని అందరికీ అందుబాటులో ఉంచవచ్చు, ఫలితంగా కొంత ఖాళీ స్థలం లభిస్తుంది:

root@ubuntu:/mnt# tune2fs -m 0 /dev/sdb1
tune2fs 1.42.9 (4-Feb-2014)
Setting reserved blocks percentage to 0% (0 blocks)

ఆ. డిఫాల్ట్‌గా, మీకు 5% డిస్క్ స్థలం వ్రాయడానికి అందుబాటులో లేదు మరియు ఆధునిక డిస్క్‌ల వాల్యూమ్‌ను బట్టి, ఇది వందల గిగాబైట్‌లు కావచ్చు.

ఇంకా ఏమి కావచ్చు? ఉచిత బ్లాక్‌లు ఉండటం కూడా సాధ్యమే, కానీ ఎక్కువ నోడ్‌లు లేవు. మీ ఫైల్ సిస్టమ్‌లో ఫైల్ సిస్టమ్ బ్లాక్ పరిమాణం కంటే చిన్న ఫైల్‌ల సమూహాన్ని కలిగి ఉంటే ఇది సాధారణంగా జరుగుతుంది. 1 ఐనోడ్ 1 ఫైల్ లేదా డైరెక్టరీపై ఖర్చు చేయబడిందని మరియు మొత్తంగా మనకు (ఇచ్చిన ఫైల్ సిస్టమ్ కోసం) 65536 ఉందని పరిగణనలోకి తీసుకుంటే - పరిస్థితి వాస్తవికత కంటే ఎక్కువ. df కమాండ్ అవుట్‌పుట్ నుండి ఇది స్పష్టంగా చూడవచ్చు:

serp@ubuntu:~$ df -hi
Filesystem     Inodes IUsed IFree IUse% Mounted on
udev             493K   480  492K    1% /dev
tmpfs            493K   425  493K    1% /run
/dev/xvda1       512K  240K  273K   47% /
none             493K     2  493K    1% /sys/fs/cgroup
none             493K     2  493K    1% /run/lock
none             493K     1  493K    1% /run/shm
none             493K     2  493K    1% /run/user
/dev/xvdc1       320K  4,1K  316K    2% /var
/dev/xvdb1        64K   195   64K    1% /home
/dev/xvdh1       4,0M  3,1M  940K   78% /var/www
serp@ubuntu:~$ df -h
Filesystem      Size  Used Avail Use% Mounted on
udev            2,0G  4,0K  2,0G   1% /dev
tmpfs           395M  620K  394M   1% /run
/dev/xvda1      7,8G  2,9G  4,6G  39% /
none            4,0K     0  4,0K   0% /sys/fs/cgroup
none            5,0M     0  5,0M   0% /run/lock
none            2,0G     0  2,0G   0% /run/shm
none            100M     0  100M   0% /run/user
/dev/xvdc1      4,8G  2,6G  2,0G  57% /var
/dev/xvdb1      990M  4,0M  919M   1% /home
/dev/xvdh1       63G   35G   25G  59% /var/www

/var/www విభజనపై స్పష్టంగా కనిపించే విధంగా, ఫైల్ సిస్టమ్‌లోని ఉచిత బ్లాక్‌ల సంఖ్య మరియు ఉచిత నోడ్‌ల సంఖ్య చాలా తేడా ఉంటుంది.

ఒకవేళ మీరు ఐనోడ్‌లు అయిపోతే, నేను మీకు ఎలాంటి మంత్రాలు చెప్పను, ఎందుకంటే... ఏవీ లేవు (నేను తప్పు అయితే, నాకు తెలియజేయండి). కాబట్టి చిన్న ఫైల్‌లు గుణించే విభజనల కోసం, మీరు ఫైల్ సిస్టమ్‌ను తెలివిగా ఎంచుకోవాలి. ఉదాహరణకు, btrfs inodes ముగియవు, ఎందుకంటే అవసరమైతే కొత్తవి డైనమిక్‌గా సృష్టించబడతాయి.

మూలం: www.habr.com

ఒక వ్యాఖ్యను జోడించండి