शोध के बाद, रैम के उपयोग की निगरानी के बारे में अभी भी भ्रम है


10

मैं इस लेख के माध्यम से गया , जो आपके रैम उपयोग की जांच करने के विभिन्न तरीकों की व्याख्या करता है। हालाँकि, मैं विभिन्न तरीकों को समेट नहीं सकता और न ही यह जानता हूं कि कौन सा सही है।

जब मैं पहली बार लॉगिन करता हूं, तो मुझे इस तरह स्क्रीन के साथ अभिवादन किया जाता है:

  System information as of Sun Apr 28 21:46:58 UTC 2013

  System load:  0.0               Processes:           76
  Usage of /:   15.6% of 7.87GB   Users logged in:     1
  Memory usage: 41%               IP address for eth0: 
  Swap usage:   0%

यह मुझे सुझाव देता है कि मैं अपने 41% रैम का उपयोग कर रहा हूं, जो कि काफी अधिक है क्योंकि सर्वर बहुत कुछ नहीं कर रहा है। या क्या वह संख्या रैम के अलावा किसी चीज़ को संदर्भित करती है?

अगले मैं free -mविधि की कोशिश :

ubuntu@ip-:~$ free -m
             total       used       free     shared    buffers     cached
Mem:           590        513         76          0         67        315
-/+ buffers/cache:        130        459
Swap:            0          0          0

लेख में व्याख्यात्मक ग्राफिक के अनुसार, इसका मतलब है कि मेरे पास 130MB उपयोग की गई रैम और 459MB की मुफ्त रैम है, जो सुझाव देता है कि मैं लगभग 22% रैम का उपयोग कर रहा हूं।

आगे मैं चला top:

top - 22:14:48 up 195 days, 21:30,  2 users,  load average: 0.00, 0.01, 0.05
Tasks:  77 total,   1 running,  76 sleeping,   0 stopped,   0 zombie
Cpu(s):  1.3%us,  0.3%sy,  0.0%ni, 97.7%id,  0.7%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:    604376k total,   525692k used,    78684k free,    69124k buffers
Swap:        0k total,        0k used,        0k free,   322740k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND            
    1 root      20   0 24332 1864  976 S  0.0  0.3   0:08.75 init               
    2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd     

यह सबसे भ्रामक है, जैसा कि सारांश मुझे कुल 604M की 525MG का उपयोग करके दिखाता है, और फिर भी जब शीर्ष मेमोरी द्वारा सॉर्ट करने के लिए "मी" इंटरैक्टिव कमांड का उपयोग किया जाता है तो शीर्ष प्रक्रिया केवल 0.3% मेमोरी का उपयोग कर रही है ???

अंत में, psकमांड बहुत कम मेमोरी उपयोग दिखाने के लिए लगता है:

root@ip-:/home/ubuntu# ps -o command,rss
COMMAND                       RSS
ps -o command,rss             788
sudo su root                 1764
su root                      1404
bash                         2132

मैं किसी के लिए प्यार करूंगा कि मेरे पास जो भी गलतफहमियां हैं, उन्हें सही करने के लिए ये स्पष्ट संघर्ष पैदा कर रहे हैं।

धन्यवाद!

राहुल के लिए EDIT

का ऊपुत cat /proc/meminfo:

MemTotal:         604376 kB
MemFree:          157564 kB
Buffers:           49640 kB
Cached:           231376 kB
SwapCached:            0 kB
Active:           290040 kB
Inactive:          97772 kB
Active(anon):     107672 kB
Inactive(anon):     4844 kB
Active(file):     182368 kB
Inactive(file):    92928 kB
Unevictable:           0 kB
Mlocked:               0 kB
SwapTotal:             0 kB
SwapFree:              0 kB
Dirty:                52 kB
Writeback:             0 kB
AnonPages:        106836 kB
Mapped:            22920 kB
Shmem:              5712 kB
Slab:              42032 kB
SReclaimable:      34016 kB
SUnreclaim:         8016 kB
KernelStack:         688 kB
PageTables:         3584 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:      302188 kB
Committed_AS:     242768 kB
VmallocTotal:   34359738367 kB
VmallocUsed:        7152 kB
VmallocChunk:   34359729008 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:      637952 kB
DirectMap2M:           0 kB

# 1) स्मृति द्वारा सॉर्ट करने के लिए शीर्ष में आदेश एम नहीं है , यह एम है । # 2) सभी प्रक्रियाओं को देखने के लिए ** ps ax -o कमांड, rss **; आप जो भागे हैं, वह आपके अपने लोगों को दिखाता है।
tink

कृपया हमें अपडेट भी करेंcat /proc/meminfo
राहुल पाटिल


@tink, उस स्पष्टीकरण के लिए धन्यवाद। मैंने कोशिश की ps ax -o rss | awk '{ sum+=$1} END {print sum}'अभी और 153156.
योना

@RahulPatil, ओपी अपडेट किया गया। ध्यान दें कि चल रही प्रक्रियाएं मूल संख्याओं से थोड़ी भिन्न हो सकती हैं, लेकिन ऐसा नहीं होना चाहिए। इसके अलावा, मुझे आपके लिए जो परिणाम मिला है, वह इस परिणाम से मेल नहीं खाता है जो मुझे इस टिप्पणी में मिला है। जिन्हें सिर्फ एक-दो मिनट के लिए अलग ले जाया गया।
योना

जवाबों:


8

आपको बस मेमोरी कॉन्सेप्ट को समझने की जरूरत है

आपके आउटपुट / proc / meminfo के अनुसार, आपको बस नीचे दी गई बातों पर ध्यान देने की आवश्यकता है:

बफ़र्स : - एक बफ़र एक ऐसी चीज़ है जिसे अभी तक डिस्क पर "लिखा" जाना है। यह दर्शाता है कि कैश डिस्क ब्लॉक को कितनी रैम समर्पित है। "कैश्ड" "बफ़र्स" के समान है, केवल इस बार यह फ़ाइल रीडिंग से पृष्ठों को कैश करता है

कैश्ड : - एक कैश एक ऐसी चीज है जिसे डिस्क से "पढ़ा" गया है और बाद में उपयोग के लिए संग्रहीत किया गया है। आम तौर पर, आप कैश क्षेत्र को एक और "फ्री" रैम के रूप में मान सकते हैं क्योंकि यह धीरे-धीरे सिकुड़ जाएगा यदि एप्लिकेशन अधिक मेमोरी की मांग करता है।

यह समझने के लिए पर्याप्त है कि "बफ़र्स" और "कैश्ड" दोनों सिस्टम कैश के आकार का प्रतिनिधित्व करते हैं। आंतरिक लिनक्स कर्नेल तंत्र द्वारा अनुरोध के अनुसार वे गतिशील रूप से बढ़ते या सिकुड़ते हैं।

Webhosting में वे cmd के नीचे कैश को स्पष्ट करते हैं: (ज्यादातर क्रोन में कॉन्फ़िगर किया गया):

sync && echo 3 > /proc/sys/vm/drop_caches

उद्धरण लिंक

एक और आवश्यकता के लिए EDIT यानी प्रति उपयोगकर्ता मेमोरी उपयोग

#!/bin/bash
total_mem=0

printf "%-10s%-10s\n" User MemUsage

while read u m
do
        [[ $old_user != $u ]] && { printf "%-10s%-0.1f\n" $old_user $total_mem; total_mem=0; }
        total_mem=$(echo $m + $total_mem | bc);
        old_user=$u

done < <(ps --no-headers -eo user,%mem| sort -k1)

#--EOF

कृपया उपरोक्त स्क्रिप्ट की जांच करें और मुझे बताएं, अगर यह ठीक से दिखा रहा है या नहीं।


धन्यवाद राहुल एक अंतिम प्रश्न। चूंकि free -mप्रति उपयोगकर्ता उपयोग की गई मेमोरी को देखने का एक तरीका प्रदान नहीं करता है, यह निर्धारित करने का एक सटीक तरीका क्या है कि किसी विशेष उपयोगकर्ता द्वारा कितनी वास्तविक रैम का उपभोग किया जा रहा है? यह तब आता है जब एक साझा सर्वर पर अपने स्वयं के मेमोरी उपयोग की निगरानी, ​​उदाहरण के लिए।
योना

@ जोना मैंने अपडेट किया है .. कृपया जांच करें और मुझे बताएं
राहुल पाटिल

वह स्क्रिप्ट उम्मीद के मुताबिक काम नहीं कर रही है .. लेकिन मैं जल्द ही अपडेट करूंगा
राहुल पाटिल

@ जोना को मेरा स्वीकार करने के लिए धन्यवाद .. लेकिन माइकल हैम्पटन के लिए असली धन्यवाद ...
राहुल पाटिल

2

अच्छा जवाब @RahulPatil।

पीएस या शीर्ष के बारे में विचार करने के लिए एक और बिंदु इस प्रकार है

यह टूल [एक्सैम्प] पीएस या टॉप की तुलना में अधिक सटीक है क्योंकि यह कई अनुप्रयोगों द्वारा उपयोग में साझा पुस्तकालयों को ध्यान में रखता है। उदाहरण के लिए, यदि दो एप्लिकेशन एक ही साझा लाइब्रेरी का उपयोग कर रहे हैं, जो 1MB मेमोरी लेता है, तो पीएस 1MB अतिरिक्त मेमोरी का उपयोग करते हुए दोनों ऐप दिखाएगा, जबकि 500 ​​KB का उपयोग करके प्रत्येक ऐप को अधिक सही तरीके से प्रदर्शित करता है। यह अधिक सटीकता केडीई और गनोम जैसे डेस्कटॉप वातावरणों के आकलन के लिए विशेष रूप से महत्वपूर्ण है, जो अनुप्रयोगों के बीच साझा किए गए पुस्तकालयों का बहुत भारी उपयोग करते हैं।

Via ibm / developerworks / linux_memory

चूंकि आपका प्रश्न एक हेडलेस सर्वर को संदर्भित करता है - मुझे यकीन नहीं है कि वास्तव में डबल रिपोर्टिंग टॉप या पीएस कितना होगा।


0

मुझे डर है कि हम स्पष्ट अनदेखी कर सकते हैं क्योंकि यह हम में से अधिकांश के लिए ऐसा "कोर्स" है।

योना, मुझे माफ कर दो अगर मैं गलत हूं, लेकिन आपके सवालों की तरह ध्वनि आपको महसूस नहीं हुई होगी कि ये सभी मूल्य, विशेष रूप से सीपीयू उपयोग, सामान्य रूप से दूसरे से दूसरे तक काफी भिन्न होंगे।

सीपीयू का उपयोग एकल अंकों से तुरंत 100% तक जा सकता है क्योंकि एक नई प्रक्रिया शुरू की जाती है, लेकिन जल्दी (उम्मीद) उप-503 सीमा तक वापस आ जाती है।

मेमोरी का उपयोग अधिक धीरे-धीरे बदलता है लेकिन वहां, लिनक्स "कैशिंग" डिस्क एक्सेस के लिए प्रक्रियाओं को चलाकर मेमोरी का उपयोग सक्रिय उपयोग में नहीं करने का प्रयास करता है। उदाहरण के लिए, यह अनुमान लगाने की कोशिश करता है कि डिस्क से आगे क्या पढ़ा जाना चाहिए, जैसे कि एक हिस्से को पढ़ने के बाद शायद एक बड़ी फाइल, और इसे कैश में पहले से लोड कर दें। मेमोरी उपयोग मूल्यों में से कुछ में प्रक्रियाओं द्वारा उपयोग की जाने वाली मेमोरी और साथ ही कैशिंग के लिए उपयोग की जाने वाली मेमोरी दोनों शामिल हैं। थोड़ी देर तक चलने वाली प्रणाली पर, दो संयुक्त संभवतः 80-90% या अधिक होंगे।

इस बात पर भी विचार करें कि आप जो प्रक्रिया उपयोग के लिए दिखाते हैं, जैसे कि topCPU और मेमोरी का उपयोग करता है। यदि आप CPU उपयोग को लगातार रिपोर्ट करने के लिए एक लूप के साथ एक स्क्रिप्ट लिखते हैं, तो यह लगभग निश्चित रूप से हमेशा 100% दिखाएगा क्योंकि उपयोग की रिपोर्ट करने का कार्य स्वयं (कुछ sleep देरी के बिना ) सभी CPU का उपयोग करता है।


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