Tomcat 6.x Perm区内存泄露问题

Tomcat 6.x

JSP文件最后改动时间大于当前系统时间导致Perm区内存泄露问题(java Memory pool CMS Perm Gen)

出现场景:

因为測试业务,须要模拟跨天測试,所以一般会採用改动server实现。来完毕測试业务,測试完毕后,不会马上同步系统时间。而直接公布上线,这时问题就出现了,因为使用穿越时间打包的,所以打包的全部文件最后改动时间都穿越了。

比如:今天是:2015.1.1  为了完毕測试,把系统时间穿越到 2015.1.5.  这个时候打包的全部文件最后改动时间都是2015.1.5号

这原本仅仅是文件的最后改动时间的穿越而已。因为Tomcat 支持JSP的热公布特性,每一个4秒就会检測一次JSP文件的变更,因为JSP文件的最后改动时间超过了当前系统时间之后的好几天。从而这几天每一个4s(Tomcat 热公布延迟时间)Tomcat就会又一次触发热公布,说白了就是使用自己定义类载入机制从新载入Class 类,因为JDK1.6 Class info 存在在Perm区,并且这个区域的内存回收很苛刻,从而导致一直大量的载入新的Class,导致Perm区内存溢出。

改动方法就是直接将公布server时间同步下,就能够了。

Tomcat 7 中已经修复这个问题了。

定位Class load  问题。能够通过在Tomcat 启动时添加JVM 參数:-XX:+TraceClassLoading -XX:+TraceClassUnloading

时间: 2024-09-30 05:40:41

Tomcat 6.x Perm区内存泄露问题的相关文章

Tomcat内存泄露解决方法

环境: 今天早上,实施人员找我说,部署在tomcat上的一个项目总是间隔一段时间就自动关闭了,我询问一些可能发生的情况后,我就找了tomcat下的日志文件catalina.2015-04-13.log,localhost.2015-04-13.log这两文件,经过一番查找后,看到了下面一段 异常详细信息介绍: http://confluence.atlassian.com/pages/viewpage.action?pageId=218275753 原因大概是说tomcat 6.025之后引入了

tomcat-reload-与内存泄露

使用的是tomcat8 ,项目 PermSize 是64mb 而项目lib 大小是33m 项目中  reloadable="true", 如果更新了class 文件,但是没有重启tomcat 那么使用一段时间后会出现Perm Space Error 的内存泄露. 可能引起的原因是 1.mysql JDBC 2.ThreadLocal 变量 3.日志框架 4.WebAppClassLoader 使用jmap 导出内存快照用eclipse memory analyser 分析发现是 jdb

JAVA内存溢出与内存泄露

虽然jvm可以通过GC自动回收无用的内存,但是代码不好的话仍然存在内存溢出的风险. 最近在网上搜集了一些资料,现整理如下: —————————————————————————————————————————— 一.为什么要了解内存泄露和内存溢出? 1.内存泄露一般是代码设计存在缺陷导致的,通过了解内存泄露的场景,可以避免不必要的内存溢出和提高自己的代码编写水平: 2.通过了解内存溢出的几种常见情况,可以在出现内存溢出的时候快速的定位问题的位置,缩短解决故障的时间. 二.基本概念 理解这两个概念非

java内存溢出和内存泄露

虽然jvm可以通过GC自动回收无用的内存,但是代码不好的话仍然存在内存溢出的风险. 最近在网上搜集了一些资料,现整理如下: —————————————————————————————————————————— 一.为什么要了解内存泄露和内存溢出? 1.内存泄露一般是代码设计存在缺陷导致的,通过了解内存泄露的场景,可以避免不必要的内存溢出和提高自己的代码编写水平: 2.通过了解内存溢出的几种常见情况,可以在出现内存溢出的时候快速的定位问题的位置,缩短解决故障的时间. 二.基本概念 理解这两个概念非

【C++】小项目——内存泄露检测器

在C++中,指针往往忘记释放.引起内存泄露. 1.内存泄露指: 内存泄漏也称作"存储渗漏",用动态存储分配函数动态开辟的空间,在使用完毕后未释放,结果导致一直占据该内存单元.直到程序结束.(其实说白了就是该内存空间使用完毕之后未回收)即所谓内存泄漏. 内存泄漏形象的比喻是"操作系统可提供给所有进程的存储空间正在被某个进程榨干",最终结果是程序运行时间越长,占用存储空间越来越多,最终用尽全部存储空间,整个系统崩溃.所以"内存泄漏"是从操作系统的角度

APNS开源包的内存泄露问题

APNS(全称:Apple Push Notification Service),主要是用于往苹果设备推送push消息通知! 基本流程: 今天要聊的问题集中在第4个环节,我们自己的服务器往苹果的消息中心推送通知. 现状: 历史原因,push的代码散落在各个应用中,随着新消息通道不断接入,开发.维护成本较高,开始考虑构建push中心, 封装dubbo接口对外提供服务,对外屏蔽各种差异,将所有的push业务逐步收扰到push中心. 过程漫长,开始接入的是个人业务,每天的调用量不大,服务器还表现正常:

浅谈C语言内存管理、内存泄露、堆栈

1.内存分配区间: 对于一个C语言程序而言,内存空间主要由五个部分组成:代码段(.text).数据段(.data).静态区(.BSS).堆和栈组成. BSS段:BSS段(bss segment)通常是指用来存放程序中未初始化的全局变量和静态变量 (这里注意一个问题:一般的书上都会说全局变量和静态变量是会自动初始化的,那么哪来的未初始化的变量呢?变量的初始化可以分为显示初始化和隐式初始化,全局变量和静态变量如果程序员自己不初始化的话的确也会被初始化,那就是不管什么类型都初始化为0,这种没有显示初始

【学习ios之路:C语言】存储区内存划分

一. 内存存储区的划分: 1.栈区:栈区主要存放函数内部定义的变量,数组.函数调用时,开辟空间,函数执行完毕,回收空间,空间的开辟与回收有系统管理. 2.堆区:堆区最大的特点:空间的开辟与释放有开发人员手动管理. 3.全局区静态区:主要存放函数外部定义的全局变量以及静态变量,空间一旦开辟,就不会回收.直到应用程序执行结束. 4.常量区:存储常量.1.整形常量.2.浮点型常量.3,字符串常量.4.字符串常量. 5.代码区:存放程序编译之后生成的cpu指令. 二.malloc,在堆区开辟空间. //

Java 程序的内存泄露问题分析

什么是内存泄露? 广义的Memory Leak:应用占用了内存,但是不再使用(包括不能使用)该部分内存 狭义的Memory Leak:应用分配了内存,但是不能再获取该部分内存的引用(对于Java,也不能被GC) 一个具体的例子: 应用创建了一个长时间运行的Thread 该Thread使用ClassLoader(可以是定制的也可以是默认的)加载了一个类 这个类有一个Static域,指向了一大块内存,然后该Thread的ThreadLocal变量保存了这个类的引用. 最后该Thread清理了对所有已