• linux系统free查看内存,发现可用物理内存很少,但是查看进程却发现没进程占用大内存


    1.现象

    当我们使用free命令查看内存的时候,发现可用物理内存很少,但是通过进程查看没有进程占用大内存。

    [root@nexus-76150 ~]# free -h
                 total       used       free     shared    buffers     cached
    Mem:           15G        15G       193M       364K       1.0G        11G
    -/+ buffers/cache:       2.2G        13G
    Swap:         7.9G        36M       7.9G
    参数值详解:
    第一行用全局角度描述系统使用的内存状况:

    total——总物理内存
    used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存
    free——完全未被使用的内存
    shared——应用程序共享内存
    buffers——缓存,主要用于目录方面,inode值等(ls大目录可看到这个值增加)
    cached——缓存,用于已打开的文件
    total=used+free used=buffers+cached (maybe add shared also)
    第二行描述应用程序的内存使用:
    前个值表示-buffers/cache——应用程序使用的内存大小,used减去缓存值 后个值表示+buffers/cache——所有可供应用程序使用的内存大小,free加上缓存值
    -buffers/cache=used-buffers-cached +buffers/cache=free+buffers+cached
    第三行表示swap的使用:
    used——已使用
    free——未使用

    [root@nexus
    -76150 ~]# ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head (这条命令是linux下获取占用内存资源最多的10个进程,若是CPU的话把4换成3就可以了) USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 2016 0.2 3.8 3390812 610608 ? Sl 2019 842:51 java -XX:MaxPermSize=192m -Djava.io.tmpdir=./tmp -Djava.net.preferIPv4Stack=true -Dcom.sun.jndi.ldap.connect.pool.protocol=plain ssl -Xms256m -Xmx768m -Djava.library.path=bin/jsw/lib -classpath bin/jsw/lib/wrapper-3.2.3.jar:./lib/jetty-http-8.1.16.v20140903.jar:./lib/jetty-client-8.1.16.v20140903.jar:./lib/jetty-security-8.1.16.v20140903.jar:./lib/logback-core-1.1.2.jar:./lib/jetty-deploy-8.1.16.v20140903.jar:./lib/metrics-core-2.2.0.jar:./lib/nexus-bootstrap-2.14.4-03.jar:./lib/metrics-logback-2.2.0.jar:./lib/jetty-server-8.1.16.v20140903.jar:./lib/jetty-rewrite-8.1.16.v20140903.jar:./lib/jul-to-slf4j-1.7.6.jar:./lib/logback-access-1.1.2.jar:./lib/jetty-util-8.1.16.v20140903.jar:./lib/metrics-jetty-2.2.0.jar:./lib/jetty-xml-8.1.16.v20140903.jar:./lib/javax.servlet-3.0.0.v201112011016.jar:./lib/slf4j-api-1.7.6.jar:./lib/jetty-jmx-8.1.16.v20140903.jar:./lib/logback-classic-1.1.2.jar:./lib/plexus-interpolation-1.16.jar:./lib/jetty-io-8.1.16.v20140903.jar:./lib/jetty-webapp-8.1.16.v20140903.jar:./lib/jetty-servlet-8.1.16.v20140903.jar:./lib/jetty-continuation-8.1.16.v20140903.jar:./conf/ -Dwrapper.key=N5Q20joBPW2LqVkr -Dwrapper.port=32000 -Dwrapper.jvm.port.min=31000 -Dwrapper.jvm.port.max=31999 -Dwrapper.pid=2014 -Dwrapper.version=3.2.3 -Dwrapper.native_library=wrapper -Dwrapper.service=TRUE -Dwrapper.cpu.timeout=10 -Dwrapper.jvmid=1 org.sonatype.nexus.bootstrap.jsw.JswLauncher ./conf/jetty.xml ./conf/jetty-requestlog.xml root 1721 0.0 0.4 4468600 68556 ? Sl 2019 274:31 java -jar desp-agent.jar zabbix 25967 0.0 0.0 77244 1024 ? S Jan08 13:07 /usr/sbin/zabbix_agentd: active checks #1 [idle 1 sec] zabbix 25966 0.0 0.0 77232 1176 ? S Jan08 4:29 /usr/sbin/zabbix_agentd: listener #3 [waiting for connection] zabbix 25965 0.0 0.0 77232 1176 ? S Jan08 4:28 /usr/sbin/zabbix_agentd: listener #2 [waiting for connection] zabbix 25963 0.0 0.0 77232 1176 ? S Jan08 4:26 /usr/sbin/zabbix_agentd: listener #1 [waiting for connection] zabbix 25962 0.0 0.0 77232 856 ? S Jan08 50:28 /usr/sbin/zabbix_agentd: collector [idle 1 sec] zabbix 25961 0.0 0.0 77232 492 ? S Jan08 0:00 /usr/sbin/zabbix_agentd -c /etc/zabbix/zabbix_agentd.conf root 95 0.0 0.0 0 0 ? S 2019 0:00 [deferwq] root 94 0.0 0.0 0 0 ? S 2019 0:00 [usbhid_resumer]

    2.原因

    通过上面我们看到内存中占用比较大的是cached,那么什么是

    Cache Memory(缓存内存)

    当你读写文件的时候,Linux内核为了提高读写性能与速度,会将文件在内存中进行缓存,这部分内存就是Cache Memory(缓存内存)。即使你的程序运行结束后,Cache Memory也不会自动释放。这就会导致你在Linux系统中程序频繁读写文件后,你会发现可用物理内存会很少。

    其实这缓存内存(Cache Memory)在你需要使用内存的时候会自动释放,所以你不必担心没有内存可用。如果你希望手动去释放Cache Memory也是有办法的。

    3.解决方法

    可以通过执行下面命令

    [root@nexus-76150 ~]#echo 3 > /proc/sys/vm/drop_caches
    参数说明:
    设置值说明:
    0:不释放(系统默认值)
    1:释放页缓存
    2:释放dentries和inodes
    3:释放所有缓存
    [root@nexus-76150 ~]# free -m
                 total       used       free     shared    buffers     cached
    Mem:         15571       1058      14512          0        132        104
    -/+ buffers/cache:        821      14749
    Swap:         8095         36       805
  • 相关阅读:
    《u-boot.lds分析》
    《uboot源码解析(二)启动第二阶段分析》
    《uboot源码解析(一)启动第一阶段——start.s分析》
    《uboot的目录结构说明》
    《uboot环境变量:详谈bootcmd 和bootargs》
    关于关注和取消关注的nodejs写法
    jquery去除字符串首尾空格的方法:$.trim()
    javascript数组去重算法-----3
    javascript数组去重算法-----2
    javascript数组去重算法-----1
  • 原文地址:https://www.cnblogs.com/qingbaizhinian/p/13130288.html
Copyright © 2020-2023  润新知