linux内存下查看出来的内存和JVM查看的为什么不一样
1、我在一台linux服务器器上装了两个应用,每个应用在JVM里配置了4G的内存;2、linux服务器的内存是16G;
当我使用高并发,无思考时间进行极限测试的时候发现如下现象:
(1)、使用free命令查看内存的时候,发现内存已经使用到15.5G;------把哥吓一跳
(2)、当我用jmap查看JVM内存使用情况的时候发现,才用了不到2G-----哥迷茫了
请问:各位大侠,知道是什么原因引起的吗?这台机器我没有在安装别的应用,并且就我一个人使用;
按理说两个应用用掉8G,在让SYS用掉2G足够了,单着才10G左右啊!!而且,当我停止并发
访问的时候发现内存并不释放。。。。我可是看着内存刚刚开机时候的8G左右一点一点涨上去
的。。只是希望有知道的大侠帮我指导一条定位的思路,可能一会说每个环境都是不一样的,你
具体跑的什么啊之类的。。这个讲不清,只要你遇到类似的问题,告诉我下啥原因我查找下我自
己的状态看是否一致。。谢谢!! (1)、使用free命令查看内存的时候,发现内存已经使用到15.5G;------把哥吓一跳
内存已经使用到15.5G并不能说明内存不够用了。linux系统的内存管理机制就是充分利用内存,可以百度一下相关资料。
你jmap看到的内存情况是你 jvm内消耗内存的情况。 这个很正常,LINUX下默认是会把可能内存都用上,当cached使用了
页:
[1]