如何在Linux系统上清空缓冲区和缓存?


315

在进行基准测试之前,如何释放Linux内核为其缓冲区和缓存消耗的内存(RAM)?


请注意,这对于基准测试最有用。清空缓冲区和缓存会降低性能!如果您在这里是因为您认为释放缓冲区和缓存是一件好事,那就去看Linux吃我的RAM!。简而言之:空闲内存就是未使用的内存就是浪费的内存。



1
@无辜的世界-从来没有看到这些时,我正在寻找,所以它似乎是在本网站上的知识库中的孔,并试图填补进去。
SLM

2
@ innocent-world-在查看这两个Q时,我认为此Q&A仍有空间。这是站点上的规范问答。这些在他们要解决的问题上是非常具体的。此外,这一节还介绍了有关分析缓冲区和缓存以及如何使用sudo设置参数的信息。其他两个问题均未解决任何一个问题。
slm

请阅读这篇文章linuxatemyram.com如果您了解风险,那么您可以进行免费&&同步&&回显3> / proc / sys / vm / drop_caches &&免费

Answers:


491

清空缓冲区缓存

如果您想清空它,可以使用此命令链。

# 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

您可以通过将上面的数字参数更改为Linux内核发出丢弃缓存项各个方面的信号。

  • 要释放页面缓存:

    # echo 1 > /proc/sys/vm/drop_caches
    
  • 要释放牙齿和索引节点:

    # echo 2 > /proc/sys/vm/drop_caches
    
  • 要释放页面缓存,牙科和索引节点:

    # echo 3 > /proc/sys/vm/drop_caches
    

以上内容旨在作为root用户运行。如果您尝试使用它们,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由于的缘故,该程序以root身份运行sudo,但是将echo的输出重定向到仅root的文件的外壳仍在以您的身份运行。您当前的外壳程序会 sudo开始之前进行重定向。

查看缓冲区和缓存中的内容

看一下linux-ftools您是否要分析缓冲区和缓存的内容。具体来说,如果您想查看当前正在缓存哪些文件。

芬科

使用此工具,您可以查看在给定目录中正在缓存哪些文件。

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

13
这么多年以后,我再也没有听说过linux-ftools,尽管我知道如何删除缓存。你真的是一个上师。感谢分享!
johnshen64

5
您说的关于同步的事情是错误的:根据linux文档,写到drop_cache只会清除干净的内容(已同步)。此外,即使它丢弃了未同步的数据,也说在清除高速缓存之前输入sync命令将保存您的数据是错误的:sync命令drop_cache写入之间的时间不为零,因此可以在此时间间隔内添加任何数据。这里没有原子。
Congelli501

3
我在这里获得了该信息:kernel.org/doc/Documentation/sysctl/vm.txt- “这是非破坏性操作,不会释放任何脏对象。” 它还说,同步可用于增加删除的缓存大小(用于写回缓存)。
Congelli501

26
优先使用“ sudo sysctl vm.drop_caches = 1”而不是“ sudo sh -c'echo 1> / proc / sys / vm / drop_caches'” –RaúlSalinas
-Monteagudo

8
@slm我喜欢用teeroot身份写:echo 3 | sudo tee /proc/sys/vm/drop-caches
pqnet
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.