文档章节

windows server 2008 环境下,运行java程序,内存耗尽问题

小叮当_加V
 小叮当_加V
发布于 2016/11/02 12:26
字数 665
阅读 417
收藏 1

经历的几天的分析,希望把自己学到的知识总结一下。

系统版本:Windows Server 2008 R2 Standard
系统类型:64bit
内存:32GB
程序:在系统上部署了solr,然后写5个线程不停的向solr查询。
问题现象:任务管理器中物理内存一直增长,最后到了99%。但是进程占用的内存加起来不到10G。

分析:

第一步:怀疑java程序内存溢出。
工具:jvisualvm与eclipse mat

jvisualvm检测是否内存溢出,如果存在内存溢出,可以用用jmap导出dump文件,再用mat分析。mat可以分析到每个类占用的内存。网上有很多mat的使用资料,大家可以自己查询。

我使用了jdk自带的jvisualvm,在jdk bin目录下jvisualvm.exe检测内存。如下图:

通过上图,发现heap会收集的,所以不存在内存溢出。为了熟悉,jmap,mat工具,我自己导出dump文件,用mat也分析了一下。

第二步:进一步分析
如果程序没有内存溢出问题,那么内存被什么占用了呢?
分析工具: RamMap与VMMap
RamMap 可以整体分析内存使用情况,VMMap可以精确到某个进程ID,他们都可以查看什么文件已经从磁盘映射到内存。

我用RAMMAP分析,发现大量的内存被Mapped File占用,点击Empty--Empty Working Sets,会释放内存,此时任务管理器内存占用下降到28%,但是内存一会又耗尽了(这里有原理,网上有资料,这种方法不可取,而且很影响系统性能)。

内存释放:

 

通过rammap与vmmap分析,发现系统把solr索引文件加载到内存中,我的索引文件有90G。对于这个mapped file我查了好多资料。大概就这样的:在windows server下进行大量IO操作时,为了提高性能,系统会默认把磁盘上的文件映射到内存,但是没有内存限制。如果磁盘文件太大,会导致内存耗尽,这也是windows server 2008 bug了。

如果限制这个内存上限呢?网上有两种方法:SetSystemFileCacheSize ,与安装微软提供的Microsoft Windows Dynamic Cache Service补丁,这个网上都有,也蛮简单,大家可以查询。

通过以上梁两种方法,依然没解决我的问题。所以,我打算在linux下试试,后续再补充博客。

© 著作权归作者所有

共有 人打赏支持
小叮当_加V
粉丝 5
博文 98
码字总数 19908
作品 0
东城
私信 提问
Windows server 2008和centos 7安装jdk

Windows server 2008和centos 7安装jdk JDK JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Jav...

luchao669
05/31
0
0
Jenkins实战演练之Windows服务器快速搭建

【准备】 操作系统:Windows Server 2008 R2 Enterprise JAVA版本:server-jre-7u45-windows-x64.tar.gz Jenkins版本:jenkins.war(v1.545) 【步骤】 采用Stand-Alone方式运行Jenkins服务器......

woneiware
2014/01/09
0
0
内存溢出之Tomcat内存配置

设置Tomcat启动的初始内存其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。 可以利用JVM提供的-Xmn -Xms -Xmx等选项可进行设置 三、实例,以下给出1G内存环境下java jv...

挨踢精英
2015/03/18
0
0
JVM的DirectMemory设置

-server 设置jvm使server模式,特点是启动速度比较慢,但运行时性能和内存管理效率很高,适用于生产环境。在具有64位能力的jdk环境下将默认启用该模式,而忽略-client参数。 几台服务器的JVM...

月下独酌100
2014/11/16
0
0
做JAVA开发的同学一定遇到过的爆表问题,看这里解决

欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由净地发表于云+社区专栏 记一次Java线上服务器CPU过载问题的排查过程,详解排查过程中用到的Java性能监测工具:jvisualvm、...

腾讯云加社区
10/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

阿里云建站

阿里云自营建站 没想到阿里云已经切入这块市场了。可以用拖动的方式来建站的模式,真的还是6.

miaojiangmin
23分钟前
2
0
linux系统top命令:virt,res,shr详解

VIRT:virtual memory usage 虚拟内存 1、进程“需要的”虚拟内存大小,包括进程使用的库、代码、数据等 2、假如进程申请100m的内存,但实际只使用了10m,那么它会增长100m,而不是实际的使用...

刘祖鹏
29分钟前
1
0
day154-2018-11-21-英语流利阅读-待学习

快手网红发明家:百万粉丝 vs 零销量 雪梨 2018-11-21 1.今日导读 “我做了一个‘雷神锤’的斜挎包,你看这里可以打开,里面可以装手机、卫生纸、钱包,觉得轻的话可以放一些砖头。咱们把它背...

飞鱼说编程
35分钟前
8
0
图灵奖得主华人高徒发布AI芯片!64位RISC-V、高度可编程,低功耗

作为RISC-V架构下的旗手玩家,睿思芯科自然希望通过产品展现出RISC-V可编程架构的巨大潜力。 https://mbd.baidu.com/newspage/data/landingshare?context=%7B%22nid%22:%22news_917924603675...

whoisliang
36分钟前
2
0
xcode 10 缺少 libstdc++6.0.9 解决方案

image.png 本方案基于xcode10正式版操作,其它版本请自行验证! 苹果在XCode10中移除了libstdc++(libstdc++.6、libstdc++6.0.9)库。 项目解决方法:删除libstdc++(libstdc++.6、libstdc++6....

壹峰
40分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部