बफ़र्स कैश को खाली करना
यदि आप इसे कभी खाली करना चाहते हैं तो आप इस श्रृंखला का उपयोग कर सकते हैं।
# free && sync && echo 3 > /proc/sys/vm/drop_caches && free
total used free shared buffers cached
Mem: 1018916 980832 38084 0 46924 355764
-/+ buffers/cache: 578144 440772
Swap: 2064376 128 2064248
total used free shared buffers cached
Mem: 1018916 685008 333908 0 224 108252
-/+ buffers/cache: 576532 442384
Swap: 2064376 128 2064248
आप ऊपर दिए गए आदेश में संख्यात्मक तर्क को बदलकर कैश्ड आइटम के विभिन्न पहलुओं को छोड़ने के लिए लिनक्स कर्नेल को संकेत कर सकते हैं।
पेजकेश को मुक्त करने के लिए:
# echo 1 > /proc/sys/vm/drop_caches
डेन्चर और इनोड्स को मुक्त करने के लिए:
# echo 2 > /proc/sys/vm/drop_caches
पेजचेस, डेंट्री और इनोड्स को मुक्त करने के लिए:
# echo 3 > /proc/sys/vm/drop_caches
उपरोक्त को मूल के रूप में चलाया जाता है। यदि आप उनका उपयोग करने की कोशिश कर रहे हैं, sudo
तो आपको सिंटैक्स को कुछ इस तरह बदलने की आवश्यकता होगी:
$ sudo sh -c 'echo 1 >/proc/sys/vm/drop_caches'
$ sudo sh -c 'echo 2 >/proc/sys/vm/drop_caches'
$ sudo sh -c 'echo 3 >/proc/sys/vm/drop_caches'
नोट: यदि आप उस में हैं तो उपरोक्त कमांड का अधिक गूढ़ संस्करण है:
$ echo "echo 1 > /proc/sys/vm/drop_caches" | sudo sh
वाक्य रचना में परिवर्तन क्यों? यह /bin/echo
प्रोग्राम रूट के रूप में चल रहा है sudo
, लेकिन शेल जो रूट-ओनली फ़ाइल में इको के आउटपुट को रीडायरेक्ट कर रहा है, वह अभी भी आपके अनुसार चल रहा है। आपका वर्तमान शेल प्रारंभ होने से पहले पुनर्निर्देशन करता है sudo
।
यह देखकर कि बफ़र्स और कैश में क्या है
linux-ftools
यदि आप बफ़र्स और कैश की सामग्री का विश्लेषण करना चाहते हैं , तो एक नज़र डालें । विशेष रूप से यदि आप यह देखना चाहते हैं कि वर्तमान में कौन सी फाइलें कैश की जा रही हैं।
fincore
इस टूल से आप देख सकते हैं कि किसी डायरेक्टरी के अंदर कौन सी फाइल कैश की जा रही हैं।
fincore [options] files...
--pages=false Do not print pages
--summarize When comparing multiple files, print a summary report
--only-cached Only print stats for files that are actually in cache.
उदाहरण के लिए /var/lib/mysql/blogindex
:
root@xxxxxx:/var/lib/mysql/blogindex# fincore --pages=false --summarize --only-cached *
stats for CLUSTER_LOG_2010_05_21.MYI: file size=93840384 , total pages=22910 , cached pages=1 , cached size=4096, cached perc=0.004365
stats for CLUSTER_LOG_2010_05_22.MYI: file size=417792 , total pages=102 , cached pages=1 , cached size=4096, cached perc=0.980392
stats for CLUSTER_LOG_2010_05_23.MYI: file size=826368 , total pages=201 , cached pages=1 , cached size=4096, cached perc=0.497512
stats for CLUSTER_LOG_2010_05_24.MYI: file size=192512 , total pages=47 , cached pages=1 , cached size=4096, cached perc=2.127660
stats for CLUSTER_LOG_2010_06_03.MYI: file size=345088 , total pages=84 , cached pages=43 , cached size=176128, cached perc=51.190476
stats for CLUSTER_LOG_2010_06_04.MYD: file size=1478552 , total pages=360 , cached pages=97 , cached size=397312, cached perc=26.944444
stats for CLUSTER_LOG_2010_06_04.MYI: file size=205824 , total pages=50 , cached pages=29 , cached size=118784, cached perc=58.000000
stats for COMMENT_CONTENT_2010_06_03.MYI: file size=100051968 , total pages=24426 , cached pages=10253 , cached size=41996288, cached perc=41.975764
stats for COMMENT_CONTENT_2010_06_04.MYD: file size=716369644 , total pages=174894 , cached pages=79821 , cached size=326946816, cached perc=45.639645
stats for COMMENT_CONTENT_2010_06_04.MYI: file size=56832000 , total pages=13875 , cached pages=5365 , cached size=21975040, cached perc=38.666667
stats for FEED_CONTENT_2010_06_03.MYI: file size=1001518080 , total pages=244511 , cached pages=98975 , cached size=405401600, cached perc=40.478751
stats for FEED_CONTENT_2010_06_04.MYD: file size=9206385684 , total pages=2247652 , cached pages=1018661 , cached size=4172435456, cached perc=45.321117
stats for FEED_CONTENT_2010_06_04.MYI: file size=638005248 , total pages=155763 , cached pages=52912 , cached size=216727552, cached perc=33.969556
stats for FEED_CONTENT_2010_06_04.frm: file size=9840 , total pages=2 , cached pages=3 , cached size=12288, cached perc=150.000000
stats for PERMALINK_CONTENT_2010_06_03.MYI: file size=1035290624 , total pages=252756 , cached pages=108563 , cached size=444674048, cached perc=42.951700
stats for PERMALINK_CONTENT_2010_06_04.MYD: file size=55619712720 , total pages=13579031 , cached pages=6590322 , cached size=26993958912, cached perc=48.533080
stats for PERMALINK_CONTENT_2010_06_04.MYI: file size=659397632 , total pages=160985 , cached pages=54304 , cached size=222429184, cached perc=33.732335
stats for PERMALINK_CONTENT_2010_06_04.frm: file size=10156 , total pages=2 , cached pages=3 , cached size=12288, cached perc=150.000000
---
total cached size: 32847278080
उपरोक्त आउटपुट के साथ आप देख सकते हैं कि कई * .MYD, * .MYI, और * .frm फाइलें हैं जो वर्तमान में कैश की जा रही हैं।
विनिमय
यदि आप अपना स्वैप साफ़ करना चाहते हैं तो आप निम्न कमांड का उपयोग कर सकते हैं।
$ free
total used free shared buffers cached
Mem: 7987492 7298164 689328 0 30416 457936
-/+ buffers/cache: 6809812 1177680
Swap: 5963772 609452 5354320
फिर स्वैप को निष्क्रिय करने के लिए इस कमांड का उपयोग करें:
$ swapoff -a
आप पुष्टि कर सकते हैं कि यह अब खाली है:
$ free
total used free shared buffers cached
Mem: 7987492 7777912 209580 0 39332 489864
-/+ buffers/cache: 7248716 738776
Swap: 0 0 0
और इसे फिर से सक्षम करने के लिए:
$ swapon -a
और अब के साथ पुन free
: पुष्टि :
$ free
total used free shared buffers cached
Mem: 7987492 7785572 201920 0 41556 491508
-/+ buffers/cache: 7252508 734984
Swap: 5963772 0 5963772