- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我几个月来一直试图追查的问题。我有一个 Java 应用程序正在运行,它处理 xml 提要并将结果存储在数据库中。存在很难追踪的间歇性资源问题。
背景:
在生产箱(问题最明显的地方)上,我没有特别好的接触箱,并且无法运行 Jprofiler。那台机器是一台运行 centos 5.2、tomcat6 和 java 1.6.0.11 的 64 位四核 8GB 机器。它从这些 java-opts 开始
JAVA_OPTS="-server -Xmx5g -Xms4g -Xss256k -XX:MaxPermSize=256m -XX:+PrintGCDetails -
XX:+PrintGCTimeStamps -XX:+UseConcMarkSweepGC -XX:+PrintTenuringDistribution -XX:+UseParNewGC"
最佳答案
好吧,我终于找到了导致此问题的问题,并且我将发布详细答案,以防其他人遇到这些问题。
我在进程运行时尝试了 jmap,但这通常会导致 jvm 进一步挂起,我必须使用 --force 运行它。这导致堆转储似乎丢失了大量数据,或者至少丢失了它们之间的引用。为了分析,我尝试了 jhat,它提供了很多数据,但在如何解释它的方式上并不多。其次,我尝试了基于eclipse的内存分析工具(http://www.eclipse.org/mat/),发现heap主要是与tomcat相关的类。
问题是 jmap 没有报告应用程序的实际状态,而只是在关闭时捕获类,这些类主要是 tomcat 类。
我又试了几次,注意到模型对象的数量非常高(实际上是数据库中标记为公开的 2-3 倍)。
我使用它分析了慢查询日志,以及一些不相关的性能问题。我尝试了超延迟加载( http://docs.jboss.org/hibernate/core/3.3/reference/en/html/performance.html ),并用直接 jdbc 查询替换了一些 hibernate 操作(主要是在处理大型集合的加载和操作的地方——jdbc 替换只是直接在连接表上工作) ,并替换了 mysql 正在记录的其他一些低效查询。
这些步骤改进了前端性能,但仍然没有解决泄漏问题,应用程序仍然不稳定并且无法预测。
最后,我找到了选项: -XX:+HeapDumpOnOutOfMemoryError 。这最终产生了一个非常大(~6.5GB)的 hprof 文件,它准确地显示了应用程序的状态。具有讽刺意味的是,文件太大了,即使在一个装有 16GB 内存的盒子上,jhat 也无法对其进行分析。幸运的是,MAT 能够生成一些漂亮的图表并显示一些更好的数据。
这次突出的是单个 quartz 线程占用了 6GB 堆中的 4.5GB,其中大部分是 hibernate 状态的 StatefulPersistenceContext ( https://www.hibernate.org/hib_docs/v3/api/org/hibernate/engine/StatefulPersistenceContext.html )。这个类在内部被 hibernate 用作它的主缓存(我已经禁用了 EHCache 支持的二级缓存和查询缓存)。
这个类用于启用hibernate的大部分功能,因此不能直接禁用它(您可以直接解决它,但spring不支持无状态 session ),如果它有这样的功能,我会感到非常惊讶成熟产品中的主要内存泄漏。那为什么现在漏水了?
嗯,这是一个组合:
quartz 线程池实例化某些东西是 threadLocal,spring 正在注入(inject)一个 session 工厂,它在 quartz 线程生命周期开始时创建一个 session ,然后被重用以运行使用 hibernate session 的各种 quartz 作业。 Hibernate 然后在 session 中缓存,这是它的预期行为。
问题是线程池从不释放 session ,因此 hibernate 状态一直驻留并在 session 的生命周期内维护缓存。由于这是使用 springs hibernate 模板支持,因此没有明确使用 session (我们使用的是 dao -> manager -> driver ->quartz-job 层次结构,dao 通过 spring 注入(inject)了 hibernate 配置,因此操作是直接在模板上完成)。
所以 session 永远不会被关闭,hibernate 维护对缓存对象的引用,所以它们永远不会被垃圾收集,所以每次运行新作业时,它只会不断填充线程本地的缓存,所以甚至没有不同作业之间的任何共享。此外,由于这是一项写入密集型工作(很少读取),因此缓存大部分都被浪费了,因此对象不断被创建。
解决方案:创建一个显式调用 session.flush() 和 session.clear() 的 dao 方法,并在每个作业开始时调用该方法。
该应用程序已经运行了几天,没有出现监控问题、内存错误或重启。
感谢大家对此的帮助,这是一个非常棘手的错误,因为一切都按照预期进行,但最终 3 行方法设法解决了所有问题。
关于java - 跟踪 Java 中的内存泄漏/垃圾收集问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1071631/
我是 C 新手,还没有真正掌握 C 何时决定释放对象以及何时决定保留对象。 heap_t 是指向结构堆的指针。 heap_t create_heap(){ heap_t h_t = (heap
我有一个问题,我不知道如何解决。问题是: char * ary = new Char[]; ifstream fle; fle.open(1.txt, ios_base::binary); fle.s
假设我在 C# 中有字符串:“我看不到你……” 我想删除(替换为空等)这些“’”符号。 我该怎么做? 最佳答案 那个“垃圾”看起来很像有人将 UTF-8 数据解释为 ISO 8859-1 或 Wi
我无法在解析方法中更改蜘蛛设置。但这绝对是一种方式。 例如: class SomeSpider(BaseSpider): name = 'mySpider' allowed_domains
在开始之前,我们先回顾一下堆是个什么玩意,大家可能都知道,我们每天创建的Java对象几乎都存放在堆上面,所以说堆是一个巨大的对象池一点都不过分,在这个对象池里面管理者数据巨大的对象实例。 在对
我想知道为什么 printf() 在提供数组且没有格式化选项时成功打印字符数组,但在使用整数数组时编译器会抛出警告并打印垃圾值。 这是我的代码: #include int main() { c
我正在研究 Scrapy 库并尝试制作一个小爬虫。 这是爬虫的规则: rules = ( Rule(LinkExtractor(restrict_xpaths='//div[@class="w
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Printing a string to a temporary stream object in C++
这个问题在这里已经有了答案: Are WebGL objects garbage collected? (2 个答案) 关闭 3 年前。 在 WebGL 中,纹理的创建和销毁使用: WebGLTex
我继承了以下代码: (为保护无辜者更改了一些名称。) package foo.bar.baz; import javax.swing.JPanel; //Main panel in the GUI c
如果我没记错的话,在某些情况下,Java 中的 lambda 会生成为匿名类实例。例如,在这段代码中,lambda 需要从外部捕获一个变量: final int local = 123456; lis
我正在阅读托管代码中的内存泄漏,想知道是否可以在 C# 不安全代码中创建它? unsafe { while(true) new int; } 我不确定如果它作为不安全代码运行,是否会被 GC
假设我有以下用 HTML 编写的网页(仅正文部分): ... function fn() { // do stu
我想知道是否有简单的命令可以删除在 latex 编译过程中生成的所有不必要的文件,例如.aux、.log 等 最好将它链接到常规的 Latex 构建命令,这样在我点击“编译”后,垃圾文件就会被删除。
Java 在 Java7 中引入了带有字符串的 switch case。我想知道使用这样的开关盒是否会产生垃圾。 例如在我的程序中, String s = getString(); switch(s)
Cevelop将 char junk 作为“未初始化的变量”对象。在这种情况下,解决问题的正确方法是什么? friend std::ostream& operator>(std::istream&
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
我正在编写一个发送和接收纯文本的小型 boost asio tcp 服务器和客户端。通信或多或少是请求响应。在测试期间,我想我只是向服务器发送垃圾数据,向它发送 100.000 个请求。 客户端发
我正在使用 SAX 来读取/解析 XML 文档,并且它工作正常,除了这个特定的站点,在该站点中 eclipse 告诉我“文档元素之后的垃圾”并且我没有返回任何数据 http://www.zachblu
这是我的 Scrapy 爬虫代码。我正在尝试从网站中提取元数据值。没有元数据在一个页面上出现多次。 class MySpider(BaseSpider): name = "courses"
我是一名优秀的程序员,十分优秀!