文档章节

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

小叮当_加V
 小叮当_加V
发布于 2016/11/02 12:26
字数 665
阅读 383
收藏 1
点赞 0
评论 0

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

系统版本: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
粉丝 4
博文 90
码字总数 18055
作品 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

应用监控平台 JavaMelody 1.73.0 发布,兼容 JDK 9

JavaMelody 1.73.0 已发布,JavaMelody 的目标是在 QA 和生产环境中监视 Java 或 Java EE 应用程序。 更新亮点: 兼容 JDK 9。请注意:要在 JDK 9 或更高版本中使用内存柱状图,需在 java 命...

王练 ⋅ 06/21 ⋅ 0

加强Docker容器与Java 10集成

很多运行在Java虚拟机(JVM)中的应用,包括数据服务如Apache Spark和Kafka以及传统企业应用,都运行在容器中。最近,运行在容器里的JVM出现了由于内存和CPU资源限制和使用率导致性能损失问题...

java高级架构牛人 ⋅ 06/04 ⋅ 0

国内首位中间件Oracle ACE:WebLogic执行线程耗尽解决方案

作者介绍 王超,国内第一位中间件ORACLE ACE,东方宏达中间件技术总监,原ORACLE|BEA 资深中间件现场支持工程师,14年现场支持工作经验,WebLogic 6.1/7.0/8.1/9.2/10.3/11g/12c、Tuxedo技术...

王超 ⋅ 2016/08/16 ⋅ 0

apache Tomcat 内存不够用?

  简介   Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,tomcat内存优化主要是对 tomcat 启动参数优化,我们可以通过修改tomcat 的启动脚本 catalina.sh(windows是catalina.ba...

linux运维菜 ⋅ 06/22 ⋅ 0

编写你的第一个HelloWorld

写在前面的话 因为Java基础是以后学习框架的基石,因此开个文集首先写写Java基础,本来想直奔基础知识的介绍,但是为了保证知识的完整性,因此从Java安装和运行“hello world”开始(虽然百度...

nanaFighting ⋅ 06/15 ⋅ 0

Android应用开发以及设计思想深度剖析(4)

特别声明:本系列文章LiAnLab.org著作权所有,转载请注明出处。作者系LiAnLab.org资深Android技术顾问吴赫老师。本系列文章交流与讨论:@宋宝华Barry 紧接连载三,我们接下从性能的角度分别分...

21cnbao ⋅ 2012/09/25 ⋅ 0

使用Docker运行Java应用程序

使用Docker运行Java应用程序 部署软件混乱; 需要克服许多问题才能生成顺畅且无痛的部署过程。诸如环境设置,依赖性地狱,编排管理以及系统可用性等问题是部署新应用程序时遇到的许多问题中的...

优惠券发放 ⋅ 05/30 ⋅ 0

JVM第一篇:一个Java内存泄漏的排查案例

最近在看《深入理解Java虚拟机:JVM高级特性与最佳实践》(第二版)这本书,理论+实践结合,深入浅出,强烈推荐给大家。 这两天在“小怪的java群”里面也对JVM内容进行了一个讨论,讨论的内容...

小怪聊职场 ⋅ 05/31 ⋅ 0

利用“进程注入”实现无文件复活 WebShell

  * 本文作者:rebeyond,本文属FreeBuf原创奖励计划,未经许可禁止转载   引子   上周末,一个好兄弟找我说一个很重要的目标shell丢了,这个shell之前是通过一个S2代码执行的漏洞拿到...

FreeBuf ⋅ 05/30 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Spring表达式语言(SpEL)

1、SpEL引用 Spring EL在bean创建时执行其中的表达式。此外,所有的Spring表达式都可以通过XML或注解的方式实现。下面将使用Spring表达式语言(SpEL),注入字符串,整数,Bean到属性。 SpEL的...

霍淇滨 ⋅ 15分钟前 ⋅ 0

Gradle使用阿里云镜像

gradle 生命周期中有一个初始化( Initialization )的过程,这个过程运行在 build script 之前,我们可以在这个地方做一点系统全局的设置,如配置仓库地址。 你可以在以下几个位置实现仓库地址...

明MikeWoo ⋅ 24分钟前 ⋅ 0

appium+python3.6

1.安装jdk1.8(不知道为啥只识别1.8,1.10不识别,所以为了少折腾,迁就安装1.8) http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 配置 JAVA_HOME:...

Kampfer ⋅ 42分钟前 ⋅ 0

详解Apache 日志分割教程

一、日志切割 安装cronolog CentOS 5.3中编译安装Apache日志默认是不切割的,需要用用工具Cronnolog进行日志切割。 1.下载及安装 wget http://cronolog.org/download/cronolog-1.6.2.tar.gz ...

dragon_tech ⋅ 45分钟前 ⋅ 0

Keepalived介绍

负载均衡器(Load Balancer, LB )是一组能够将IP数据流以负载均衡形式转发到多台物理服务器的集成软件。有硬件负载均衡器和软件负载均衡器之分,硬件负载均衡器主要是在访问网络和服务器之间...

寰宇01 ⋅ 45分钟前 ⋅ 0

java8-Collections and Streams

stream和集合的区别是什么? 1.在计算的时候处理不同, 2.every element should be computed in the memory and then to be part of collections stream Stream apis filter with a predica......

writeademo ⋅ 50分钟前 ⋅ 0

Confluence 6 重新获得附件指南

每一个文件在恢复上传到 Confluence 的时候必须单独重命名,你可以通过下面说明的 3 个方法中选择一个进行操作: 选择 A - 通过文件名恢复附件 如果你知道你需要恢复的每一个文件名,尤其是你...

honeymose ⋅ 今天 ⋅ 0

【每天一个JQuery特效】根据状态确定是否滑入或滑出被选元素

主要效果: 本文主要采用slideToggle()方法实现以一行代码同时实现以展开或收缩的方式显示或隐藏被选元素。 主要代码如下: <!DOCTYPE html><html><head><meta charset="UTF-8">...

Rhymo-Wu ⋅ 今天 ⋅ 0

度量.net framework 迁移到.net core的工作量

把现有的.net framework程序迁移到.net core上,是一个非常复杂的工作,特别是一些API在两个平台上还不能同时支持。两个类库的差异性,通过人工很难识别全。好在微软的工程师们考虑到了我们顾...

李朝强 ⋅ 今天 ⋅ 0

请不要在“微服务”的狂热中迷失自我!

微服务在过去几年一直是一个非常热门的话题(附录1)。何为“微服务的疯狂”,举个例子: 众所周知,Netflix在DevOps上的表现非常棒。Netfix可以做微服务。因此:如果我做微服务,我也将非常...

harries ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部