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

 

posted @ 2020-06-15 13:19  清白之年980410  阅读(9027)  评论(0编辑  收藏  举报