• Linux下清理内存和Cache方法见下文:


    暂时目前的环境处理方法比较简单:

    在root用户下添加计划任务:

    */10 * * * * sync;echo 3 > /proc/sys/vm/drop_caches;     

    每十分钟执行一次,先将脏数据写回硬盘,之后释放缓存页和入口信息和节点信息等;

    -------------------参考链接:

    http://man.linuxde.net/sync

    https://www.linuxidc.com/Linux/2010-03/24939.htm

    sync命令

     

    sync命令用于强制被改变的内容立刻写入磁盘,更新超块信息。

    在Linux/Unix系统中,在文件或数据处理过程中一般先放到内存缓冲区中,等到适当的时候再写入磁盘,以提高系统的运行效率。sync命令则可用来强制将内存缓冲区中的数据立即写入磁盘中。用户通常不需执行sync命令,系统会自动执行update或bdflush操作,将缓冲区的数据写 入磁盘。只有在update或bdflush无法执行或用户需要非正常关机时,才需手动执行sync命令。

    语法

    sync(选项)

    选项

    --help:显示帮助;
     --version:显示版本信息。

    buffer与cache

    • buffer:为了解决写磁盘的效率
    • cache:为了解决读磁盘的效率

    linux系统为了提高读写磁盘的效率,会先将数据放在一块buffer中。在写磁盘时并不是立即将数据写到磁盘中,而是先写入这块buffer中了。此时如果重启系统,就可能造成数据丢失。

    sync命令用来flush文件系统buffer,这样数据才会真正的写到磁盘中,并且buffer才能够释放出来,flush就是用来清空buffer。sync命令会强制将数据写入磁盘中,并释放该数据对应的buffer,所以常常会在写磁盘后输入sync命令来将数据真正的写入磁盘。

    如果不去手动的输入sync命令来真正的去写磁盘,linux系统也会周期性的去sync数据。

    ----------------------

     

    Linux下清理内存和Cache方法 /proc/sys/vm/drop_caches


    Linux下清理内存和Cache方法 /proc/sys/vm/drop_caches
     

    频繁的文件访问会导致系统的Cache使用量大增

    $ free -m
    total used free shared buffers cached
    Mem: 3955 3926 28 0 55 3459
    -/+ buffers/cache: 411 3544
    Swap: 5726 0 5726

    free内存减少到几十兆,系统运行缓慢

    运行sync将dirty的内容写回硬盘
    $sync

    通过修改proc系统的drop_caches清理free的cache
    $echo 3 > /proc/sys/vm/drop_caches

    drop_caches的详细文档如下:
    Writing to this will cause the kernel to drop clean caches, dentries and inodes from memory, causing that memory to become free.
    To free pagecache:
    * echo 1 > /proc/sys/vm/drop_caches
    To free dentries and inodes:
    * echo 2 > /proc/sys/vm/drop_caches
    To free pagecache, dentries and inodes:
    * echo 3 > /proc/sys/vm/drop_caches
    As this is a non-destructive operation, and dirty objects are notfreeable, the user should run "sync" first in order to make sure allcached objects are freed.
    This tunable was added in 2.6.16.

    修改/etc/sysctl.conf 添加如下选项后就不会内存持续增加
    vm.dirty_ratio = 1
    vm.dirty_background_ratio=1
    vm.dirty_writeback_centisecs=2
    vm.dirty_expire_centisecs=3
    vm.drop_caches=3
    vm.swappiness =100
    vm.vfs_cache_pressure=163
    vm.overcommit_memory=2
    vm.lowmem_reserve_ratio=32 32 8
    kern.maxvnodes=3

    上面的设置比较粗暴,使cache的作用基本无法发挥。需要根据机器的状况进行适当的调节寻找最佳的折衷。

  • 相关阅读:
    Linux内存管理1---内存寻址
    UML和模式应用5:细化阶段(10)---UML交互图
    AT91RM9200---电源管理控制器(PMC)介绍
    AT91RM9200---定时器简介
    [转]指针大小是由谁决定的?
    UML和模式应用5:细化阶段(9)---迈向对象设计
    UML和模式应用5:细化阶段(8)---逻辑架构和UML包图
    UML和模式应用5:细化阶段(7)---从需求到设计迭代进化
    UML和模式应用5:细化阶段(6)---操作契约
    VxWorks软件开发项目实例完全解析1-VxWorks简介
  • 原文地址:https://www.cnblogs.com/the-tops/p/8798630.html
Copyright © 2020-2023  润新知