लिनक्स एडमिन - कोटा प्रबंधन

CentOS डिस्क कोटा दोनों सक्षम किया जा सकता है; सिस्टम व्यवस्थापक को सचेत करना और डिस्क क्षमता से अधिक होने से पहले किसी उपयोगकर्ता को डिस्क-स्टोरेज-एक्सेस से वंचित करना। जब एक डिस्क भरी होती है, तो डिस्क पर क्या निर्भर करता है, इस पर निर्भर करते हुए, एक संपूर्ण सिस्टम पुनर्प्राप्त करने के लिए एक डरावना पड़ाव पर आ सकता है।

CentOS Linux में कोटा प्रबंधन सक्षम करना मूल रूप से एक 4 कदम प्रक्रिया है -

  • Step 1 - / आदि / fstab में समूहों और उपयोगकर्ताओं के लिए कोटा प्रबंधन सक्षम करें।

  • Step 2 - फाइल सिस्टम को रिमूव करें।

  • Step 3 - कोटा डेटाबेस बनाएं और डिस्क उपयोग तालिका उत्पन्न करें।

  • Step 4 - कोटा नीतियों को असाइन करें।

कोटा प्रबंधन को / etc / fstab में सक्षम करें

सबसे पहले, हम अपने / etc / fstab फाइलन का बैकअप लेना चाहते हैं -

[root@centosLocal centos]# cp -r /etc/fstab ./

अब हमारे पास वर्तमान कार्यशील निर्देशिका में हमारे ज्ञात कार्य / etc / fstab की एक प्रति है ।

# 
# /etc/fstab 
# Created by anaconda on Sat Dec 17 02:44:51 2016 
# 
# Accessible filesystems, by reference, are maintained under '/dev/disk' 
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
# 
/dev/mapper/cl-root        /         xfs     defaults                      0 0
UUID = 4b9a40bc-9480-4     /boot     xfs     defaults                      0 0

/dev/mapper/cl-home        /home     xfs     defaults,usrquota,grpquota    0 0

/dev/mapper/cl-swap        swap      swap    defaults                      0 0

हमने वॉल्यूम या लेबल के लिए विकल्पों में अनुभाग / etc / fstab में निम्नलिखित परिवर्तन किए हैं जहाँ उपयोगकर्ताओं और समूहों के लिए कोटा लागू किया जाना है।

  • usrquota
  • grpquota

जैसा कि आप देख सकते हैं, हम उपयोग कर रहे हैं xfsफाइल सिस्टम। Xfs का उपयोग करते समय अतिरिक्त मैनुअल चरण शामिल होते हैं।/home/ के रूप में एक ही डिस्क पर है। आगे की जांच से पता चलता है कि नोक्वोटा के लिए सेट किया गया है , जो कर्नेल स्तर पर बढ़ते विकल्प है। हमें अपने कर्नेल बूट विकल्पों को फिर से कॉन्फ़िगर करना होगा।

root@localhost rdc]# mount | grep ' / ' 
/dev/mapper/cl-root on / type xfs (rw,relatime,seclabel,attr2,inode64,noquota)

[root@localhost rdc]#

XFS फ़ाइल सिस्टम के लिए कर्नेल बूट विकल्प को फिर से कॉन्फ़िगर करना

यह कदम केवल दो शर्तों के तहत आवश्यक है -

  • जब डिस्क / विभाजन हम कोटा को सक्षम कर रहे हैं, xfs फाइल सिस्टम का उपयोग कर रहा है
  • जब कर्नेल बूट समय पर / etc / fstab को noquota पैरामीटर दे रहा है

Step 1 - / etc / default / grub का बैकअप बनाएं।

cp /etc/default/grub ~/

Step 2- संशोधित / आदि / डिफ़ॉल्ट / ग्रब

यहाँ डिफ़ॉल्ट फ़ाइल है।

GRUB_TIMEOUT=5 
GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc/system-release)" 
GRUB_DEFAULT=saved 
GRUB_DISABLE_SUBMENU=true 
GRUB_TERMINAL_OUTPUT="console" 
GRUB_CMDLINE_LINUX="crashkernel=auto rd.lvm.lv=cl/root rd.lvm.lv=cl/swap rhgb quiet" 
GRUB_DISABLE_RECOVERY="true"

हम निम्नलिखित पंक्ति को संशोधित करना चाहते हैं -

GRUB_CMDLINE_LINUX="crashkernel=auto rd.lvm.lv=cl/root rd.lvm.lv=cl/swap rhgb quiet"

सेवा

GRUB_CMDLINE_LINUX="crashkernel=auto rd.lvm.lv=cl/root rd.lvm.lv 
=cl/swap rhgb quiet rootflags=usrquota,grpquota"

Note- यह महत्वपूर्ण है कि हम इन परिवर्तनों को शब्दशः कॉपी करें। यदि हम grub.cfg को फिर से कॉन्फ़िगर करते हैं, तो कॉन्फ़िगरेशन में कोई त्रुटि होने पर हमारा सिस्टम बूट करने में विफल हो जाएगा। कृपया, गैर-उत्पादन प्रणाली पर ट्यूटोरियल के इस भाग को आज़माएँ।

Step 3 - बैकअप अपने काम grub.cfg

cp /boot/grub2/grub.cfg /boot/grub2/grub.cfg.bak

एक नया grub.cfg बनाएं

[root@localhost rdc]# grub2-mkconfig -o /boot/grub2/grub.cfg 
Generating grub configuration file ... 
Found linux image: /boot/vmlinuz-3.10.0-514.el7.x86_64 
Found initrd image: /boot/initramfs-3.10.0-514.el7.x86_64.img 
Found linux image: /boot/vmlinuz-0-rescue-dbba7fa47f73457b96628ba8f3959bfd 
Found initrd image: /boot/initramfs-0-rescuedbba7fa47f73457b96628ba8f3959bfd.img 
done

[root@localhost rdc]#

रीबूट

[root@localhost rdc]#reboot

यदि सभी संशोधन सटीक थे, तो हमें एक्सएफ़एस फाइल सिस्टम में कोटा जोड़ने की उपलब्धता नहीं होनी चाहिए ।

[rdc@localhost ~]$ mount | grep ' / ' 
/dev/mapper/cl-root on / type xfs (rw,relatime,seclabel,attr2,inode64,usrquota,grpquota)
 
[rdc@localhost ~]$

हम ग्रब के माध्यम से usrquota और grpquota मापदंडों को पारित कर चुके हैं ।

अब, फिर से संपादित करें / etc / fstab / के बाद से शामिल करने के लिए / homeon एक ही भौतिक डिस्क।

/dev/mapper/cl-root/xfs
defaults,usrquota,grpquota        0 0

अब कोटा डेटाबेस को सक्षम करते हैं।

[root@localhost rdc]# quotacheck -acfvugM

सुनिश्चित करें कि कोटा सक्षम हैं।

[root@localhost rdc]# quotaon -ap 
group quota on / (/dev/mapper/cl-root) is on 
user quota on / (/dev/mapper/cl-root) is on 
group quota on /home (/dev/mapper/cl-home) is on 
user quota on /home (/dev/mapper/cl-home) is on 
[root@localhost rdc]#

फाइल सिस्टम को रिमूव करें

यदि विभाजन या डिस्क सक्रिय रूप से बूट किए गए विभाजन से अलग है, तो हम रिबूट किए बिना रिमाउंट कर सकते हैं। यदि कोटा रूट डायरेक्टरी में बूट / डिस्क पर कॉन्फ़िगर किया गया था, तो हमें ऑपरेटिंग सिस्टम को रिबूट करना पड़ सकता है। रिमाउंट को लागू करने और परिवर्तनों को लागू करने के लिए, फाइल सिस्टम को रिमूव करने की आवश्यकता भिन्न हो सकती है।

[rdc@localhost ~]$ df 
Filesystem              1K-blocks     Used      Available      Use%     Mounted on
/dev/mapper/cl-root     22447404      4081860   18365544       19%         /
devtmpfs                903448        0         903448         0%          /dev
tmpfs                   919308        100       919208         1%          /dev/shm
tmpfs                   919308        9180      910128         1%          /run
tmpfs                   919308        0         919308         0%          /sys/fs/cgroup
/dev/sda2               1268736       176612    1092124        14%         /boot
/dev/mapper/cl-var      4872192       158024    4714168        4%          /var
/dev/mapper/cl-home     18475008      37284     18437724       1%          /home
tmpfs                   183864        8         183856         1%          /run/user/1000

[rdc@localhost ~]$

जैसा कि हम देख सकते हैं, LVM वॉल्यूम उपयोग में हैं। तो यह सिर्फ रिबूट करने के लिए सरल है। यह / होम / रीमाउंट करेगा और / etc / fstab कॉन्फ़िगरेशन परिवर्तनों को सक्रिय कॉन्फ़िगरेशन में लोड करेगा ।

कोटा डेटाबेस फ़ाइलें बनाएँ

CentOS अब डिस्क कोटा के साथ / घर पर काम करने में सक्षम है। पूर्ण कोटा सपॉर्ट को सक्षम करने के लिए, हमें चलाना होगाquotacheck आदेश।

quotacheck दो फाइलें बनाएगी -

  • aquota.user
  • aquota.group

ये कोटा सक्षम डिस्क / विभाजन के लिए कोटा जानकारी संग्रहीत करने के लिए उपयोग किया जाता है।

निम्नलिखित सामान्य उद्धरण स्विच हैं।

स्विच कार्य
यू उपयोगकर्ता कोटा के लिए जाँच करता है
जी समूह कोटा के लिए जाँच करता है
-सी कोटा को सक्षम करने के साथ प्रत्येक फाइल सिस्टम के लिए कोटा सक्षम होना चाहिए
-v वर्बोज़ आउटपुट प्रदर्शित करता है

प्रति उपयोगकर्ता कोटा सीमाएँ जोड़ें

इसके लिए, हम edquota कमांड का उपयोग करेंगे, उसके बाद उपयोगकर्ता नाम -

[root@localhost rdc]# edquota centos

Disk quotas for user centos (uid 1000):  
Filesystem                   blocks       soft       hard     inodes     soft     hard 
/dev/mapper/cl-root              12          0          0         13        0        0  
/dev/mapper/cl-home            4084          0          0        140        0        0

आइए प्रत्येक कॉलम को देखें।

  • Filesystem - यह उपयोगकर्ता के लिए लागू किया गया फाइलसिस्टम कोटा है

  • blocks - उपयोगकर्ता प्रत्येक फाइलसिस्टम पर वर्तमान में कितने ब्लॉक का उपयोग कर रहा है

  • soft- नरम सीमा के लिए ब्लॉक सेट करें। शीतल सीमा उपयोगकर्ता को एक निश्चित समयावधि के लिए कोटा ले जाने की अनुमति देती है

  • hard- हार्ड लिमिट के लिए ब्लॉक सेट करें। हार्ड लिमिट कुल स्वीकार्य कोटा है

  • inodes - वर्तमान में उपयोगकर्ता कितने इनकोड का उपयोग कर रहा है

  • soft - नरम इनोड सीमा

  • hard - हार्ड इनोड सीमा

एक उपयोगकर्ता के रूप में हमारे वर्तमान कोटा की जांच करने के लिए -

[centos@localhost ~]$ quota 
Disk quotas for user centos (uid 1000):  
Filesystem             blocks     quota      limit grace    files   quota   limit   grace 
/dev/mapper/cl-home    6052604    56123456   61234568       475     0       0       [centos@localhost ~]$

निम्नलिखित उपयोगकर्ता को एक त्रुटि दी जाती है जब हार्ड कोटा सीमा पार हो गई है।

[centos@localhost Downloads]$ cp CentOS-7-x86_64-LiveKDE-1611.iso.part ../Desktop/

cp: cannot create regular file ‘../Desktop/CentOS-7-x86_64-LiveKDE-
1611.iso.part’: Disk quota exceeded

[centos@localhost Downloads]$

जैसा कि हम देख सकते हैं, हम इस उपयोगकर्ता की डिस्क कोटा के भीतर हैं। चलो एक नरम सीमा चेतावनी सेट करें। इस तरह, कोटा सीमा समाप्त होने से पहले उपयोगकर्ता के पास अग्रिम सूचना होगी। अनुभव से, आपको अंत-उपयोगकर्ता की शिकायतें मिलेंगी जब वे काम में आएंगे और वास्तव में काम करने के लिए 45 मिनट क्लियरिंग फ़ाइलों को खर्च करने की आवश्यकता होगी।

एक प्रशासक के रूप में, हम कोटा के उपयोग की जाँच कर सकते हैं repquota आदेश।

[root@localhost Downloads]# repquota  /home  
                    Block limits                            File limits  
User            used     soft     hard     grace       used     soft     hard     grace 
----------------------------------------------------------------------------------------
root      --       0         0        0                   3        0        0        
centos    -+ 6189824  56123456 61234568                 541      520      540      6days 

[root@localhost Downloads]#

जैसा कि हम देख सकते हैं, उपयोगकर्ता सेंटो ने अपने हार्ड ब्लॉक कोटा को पार कर लिया है और अब / घर पर किसी भी अधिक डिस्क स्थान का उपयोग नहीं कर सकता है

- '' निरूपित करता है कि फाइल सिस्टम पर एक कठिन कोटा खत्म कर दिया गया है।

कोटा की योजना बनाते समय, थोड़ा गणित करना आवश्यक है। एक प्रशासक को क्या जानना चाहिए: सिस्टम पर कितने उपयोगकर्ता हैं? उपयोगकर्ताओं / समूहों के बीच आवंटित करने के लिए कितना खाली स्थान है? फ़ाइल सिस्टम पर कितने बाइट्स एक ब्लॉक बनाते हैं?

मुक्त डिस्क- स्पेस से संबंधित ब्लॉक के संदर्भ में कोटा को परिभाषित करें। यह फाइल सिस्टम पर फ्री-स्पेस के "सुरक्षित" बफर को छोड़ने की सिफारिश की गई है जो सबसे खराब स्थिति में रहेगा: सभी कोटा एक साथ पार हो गए हैं। यह विशेष रूप से एक विभाजन पर है जो सिस्टम द्वारा लॉग लिखने के लिए उपयोग किया जाता है।