लिनक्स एडमिन - क्रॉस्प्स के साथ संसाधन Mgmt

cgroups या Control Group लिनक्स कर्नेल की एक विशेषता है जो प्रशासक को सेवाओं और समूह के लिए सिस्टम संसाधनों को आवंटित या कैप करने की अनुमति देता है।

सक्रिय नियंत्रण समूहों की सूची बनाने के लिए , हम निम्नलिखित ps कमांड का उपयोग कर सकते हैं -

[root@localhost]# ps xawf -eo pid,user,cgroup,args 
8362 root     -                            \_ [kworker/1:2] 
1 root        -                           /usr/lib/systemd/systemd --switched-
   root --system --    deserialize 21 
507 root     7:cpuacct,cpu:/system.slice  /usr/lib/systemd/systemd-journald 
527 root     7:cpuacct,cpu:/system.slice  /usr/sbin/lvmetad -f 
540 root     7:cpuacct,cpu:/system.slice  /usr/lib/systemd/systemd-udevd 
715 root     7:cpuacct,cpu:/system.slice  /sbin/auditd -n 
731 root     7:cpuacct,cpu:/system.slice   \_ /sbin/audispd 
734 root     7:cpuacct,cpu:/system.slice       \_ /usr/sbin/sedispatch 
737 polkitd  7:cpuacct,cpu:/system.slice  /usr/lib/polkit-1/polkitd --no-debug 
738 rtkit    6:memory:/system.slice/rtki  /usr/libexec/rtkit-daemon 
740 dbus     7:cpuacct,cpu:/system.slice  /bin/dbus-daemon --system --
   address=systemd: --nofork --nopidfile --systemd-activation

CentOS 6.X के रूप में संसाधन प्रबंधन, सिस्टमिड इनिट कार्यान्वयन के साथ पुनर्परिभाषित किया गया है । जब सेवाओं के लिए संसाधन प्रबंधन सोच रहा है, तो मुख्य बात cgroups हैंcgroupsकार्यक्षमता और सरलता दोनों में सिस्टमड के साथ उन्नत किया है ।

संसाधन प्रबंधन में cgroups का लक्ष्य -no एक सेवा है, सिस्टम को संपूर्ण रूप में, नीचे ले जा सकता है। या कोई एकल सेवा प्रक्रिया (शायद खराब लिखी गई PHP स्क्रिप्ट) बहुत अधिक संसाधनों का उपभोग करके सर्वर की कार्यक्षमता को अपंग कर देगी।

cgroups निम्नलिखित संसाधनों के लिए इकाइयों के संसाधन नियंत्रण की अनुमति देते हैं -

  • CPU - सीमित सीपीयू गहन कार्य जो अन्य महत्वपूर्ण नहीं हैं, कम गहन कार्य

  • Memory - एक सेवा कितनी मेमोरी का उपभोग कर सकती है, इसे सीमित करें

  • Disks - सीमा डिस्क i / o

** CPU समय: **

कम CPU प्राथमिकता वाले कार्यों में कस्टम कॉन्फ़िगर CPU स्लाइस हो सकते हैं।

आइए, उदाहरण के लिए निम्नलिखित दो सेवाओं पर एक नज़र डालें।

विनम्र CPU सेवा 1

[root@localhost]# systemctl cat polite.service 
# /etc/systemd/system/polite.service 
[Unit] 
Description = Polite service limits CPU Slice and Memory 
After=remote-fs.target nss-lookup.target

[Service] 
MemoryLimit = 1M 
ExecStart = /usr/bin/sha1sum /dev/zero 
ExecStop = /bin/kill -WINCH ${MAINPID} 
WantedBy=multi-user.target

# /etc/systemd/system/polite.service.d/50-CPUShares.conf 
[Service] 
CPUShares = 1024 
[root@localhost]#

बुराई सीपीयू सेवा 2

[root@localhost]# systemctl cat evil.service 
# /etc/systemd/system/evil.service 
[Unit] 
Description = I Eat You CPU 
After=remote-fs.target nss-lookup.target

[Service] 
ExecStart = /usr/bin/md5sum /dev/zero 
ExecStop = /bin/kill -WINCH ${MAINPID} 
WantedBy=multi-user.target

# /etc/systemd/system/evil.service.d/50-CPUShares.conf 
[Service] 
CPUShares = 1024 
[root@localhost]#

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

systemctl set-property polite.service CPUShares = 20  
/system.slice/polite.service
1   70.5   124.0K        -        -  

/system.slice/evil.service
1   99.5   304.0K        -        -

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

प्रत्येक संसाधन के लिए सेवाएं निर्धारित करने के लिए, सेट-प्रॉपर्टी विधि निम्नलिखित मापदंडों को परिभाषित करती है -

systemctl set-property name parameter=value

सीपीयू स्लाइस CPUShares
मेमोरी सीमा MemoryLimit
शीतल मेमोरी सीमा MemorySoftLimit
ब्लॉक आईओ वजन BlockIOWeight
ब्लॉक डिवाइस सीमा (/ मात्रा / पथ में निर्दिष्ट) BlockIODeviceWeight
IO पढ़ें BlockIOReadBandwidth
डिस्क लिखें IO BlockIOReadBandwidth

सीपीयू के उपयोग , मेमोरी लिमिट और रीड / राइट आईओ द्वारा ज्यादातर सेवाएं सीमित होंगी ।

प्रत्येक को बदलने के बाद, सिस्टम को फिर से लोड करना और सेवा को पुनरारंभ करना आवश्यक है -

systemctl set-property foo.service CPUShares = 250 
systemctl daemon-reload 
systemctl restart foo.service

CentOS Linux में CGroups कॉन्फ़िगर करें

CentOS Linux में कस्टम cgroups बनाने के लिए, हमें पहले सेवाओं को स्थापित करने और उन्हें कॉन्फ़िगर करने की आवश्यकता है।

Step 1 - libcgroup स्थापित करें (यदि पहले से स्थापित नहीं है)।

[root@localhost]# yum install libcgroup 
Package libcgroup-0.41-11.el7.x86_64 already installed and latest version 
Nothing to do 
[root@localhost]#

जैसा कि हम देख सकते हैं, डिफ़ॉल्ट रूप से CentOS 7 में सब कुछ इंस्टॉलर के साथ libcgroup स्थापित है। न्यूनतम इंस्टॉलर का उपयोग करने से हमें किसी भी निर्भरता के साथ libcgroup उपयोगिताओं को स्थापित करने की आवश्यकता होगी ।

Step 2 - cgconfig सेवा शुरू या सक्षम करें।

[root@localhost]# systemctl enable cgconfig 
Created symlink from /etc/systemd/system/sysinit.target.wants/cgconfig.service 
to /usr/lib/systemd/system/cgconfig.service. 
[root@localhost]# systemctl start cgconfig 
[root@localhost]# systemctl status cgconfig 
● cgconfig.service - Control Group configuration service 
Loaded: loaded (/usr/lib/systemd/system/cgconfig.service; enabled; vendor 
preset: disabled) 
Active: active (exited) since Mon 2017-01-23 02:51:42 EST; 1min 21s ago 
Main PID: 4692 (code=exited, status = 0/SUCCESS) 
Memory: 0B 
CGroup: /system.slice/cgconfig.service  

Jan 23 02:51:42 localhost.localdomain systemd[1]: Starting Control Group 
configuration service... 
Jan 23 02:51:42 localhost.localdomain systemd[1]: Started Control Group 
configuration service. 
[root@localhost]#