- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在高负载多线程Java项目中遇到OOM异常问题。
我很感激你能给我任何帮助。
德莱尔斯:
项目是建立在Java+Mysql作为存储。
没有证据表明在应用程序崩溃时会使用额外的RAM(任何监控工具都不会跳转)
CPU和I/O也可以。
Jstack工具未找到任何线程死锁。
Mysql中没有慢速或错误日志。
在hs_err中,您可以看到thread_blocked状态,但我没有找到任何原因。
Java运行参数、系统限制、可用内存,如下所示。
以下是hs_err_filepart中的错误(完整文件attached):
内存不足,Java运行时环境无法继续。
本机内存分配(mmap)无法映射1633681408字节以提交保留内存。
可能的原因:
系统的物理RAM或交换空间不足
在32位模式下,已达到进程大小限制
可能的解决方案:
减少系统内存负载
增加物理内存或交换空间
检查交换备份存储是否已满
在64位操作系统上使用64位Java
减小Java堆大小(-Xmx/-Xms)
减少Java线程数
减少Java线程堆栈大小(-Xss)
使用-XX:ReservedCodeCacheSize设置更大的代码缓存=
此输出文件可能被截断或不完整。
内存不足错误(os_linux.cpp:2627),pid=11980,tid=0x00007f27148c8700
JRE版本:Java(TM)SE运行时环境(8.0_92-b14)(内部版本1.8.0_92-b14)
Java虚拟机:Java HotSpot(TM)64位服务器虚拟机(25.92-b14混合模式linux-amd64压缩oops)
无法写入核心转储。已禁用核心转储。要启用核心转储,请在再次启动Java之前尝试“ulimit-c unlimited”
---------------今天---------------
当前线程(0x00007f27883c5800):VMThread[堆栈:0x00007f27147c8000,0x00007f27148c9000][id=12005]
堆栈:[0x00007f27147c8000,0x00007f27148c9000],sp=0x00007f27148c7160,可用空间=1020k
本机帧:(J=编译的Java代码,J=解释的,Vv=虚拟机代码,C=本机代码)
V[libjvm.so+0xabd65a]VMError::report_and_die()+0x2ba
V[libjvm.so+0x4fb4db]报告内存不足(char const*,int,unsigned long,VMErrorType,char const*)+0x8b
V[libjvm.so+0x91d713]os::Linux::commit_memory_impl(char*,unsigned long,bool)+0x103
V[libjvm.so+0x91dc69]os::pd_commit_内存(char*,unsigned long,unsigned long,bool)+0x29
V[libjvm.so+0x917f6a]os::提交内存(char*,unsigned long,unsigned long,bool)+0x2a
V[libjvm.so+0x98c343]PSVirtualSpace::expand_by(unsigned long)+0x53
V[libjvm.so+0x98d748]PSYoungGen::调整生成大小(无符号长,无符号长)+0xf8
V[libjvm.so+0x98c8a2]PSYoungGen::resize(无符号长,无符号长)+0x22
V[libjvm.so+0x989b7b]PSScavenge::invoke_no_policy()+0xf3b
V[libjvm.so+0x98a301]PSScavenge::invoke()+0x41
V[libjvm.so+0x941410]并行清除heap::分配内存失败(无符号长)+0x70
V[libjvm.so+0xabf077]虚拟机并行失败分配::doit()+0x97
V[libjvm.so+0xac6aa5]虚拟机操作::evaluate()+0x55
V[libjvm.so+0xac4e7a]VMThread::evaluate_操作(VM_操作*)+0xba
V[libjvm.so+0xac51fe]VMThread::loop()+0x1ce
V[libjvm.so+0xac5670]VMThread::run()+0x70
V[libjvm.so+0x91fad8]java启动(线程*)+0x108
VM_操作(0x00007f22963f34e0):并行gcfailedallocation,模式:safepoint,由线程0x00007f25e8105000请求
---------------P R O C E S公司---------------
Java线程:(=>当前线程)
0x00007f25a8052800 JavaThread“pool-27-thread-32”[_thread_blocked,id=26278,stack(0x00007f2147523000,0x00007f214762400)]
0x00007f24dc07f000 JavaThread“pool-33-thread-55”[线程被阻塞,id=26277,堆栈(0x00007f214762400,0x00007f2147725000)]
0x00007f25bc06b800 JavaThread“pool-28-thread-48”[线程被阻塞,id=26272,堆栈(0x00007f2147725000,0x00007f214782600)]
0x00007f256806000 JavaThread“pool-24-thread-39”[_thread_blocked,id=26267,stack(0x00007f2147826000,0x00007f2147927000)]
0x00007f25bc06a000 JavaThread“pool-28-thread-47”[线程被阻塞,id=26262,堆栈(0x00007f2147927000,0x00007f2147a28000)]
jvm_args:-Xmx16G-XX:ReservedCodeCacheSize=256M-XX:+HeapDumpOnOutOfMemoryError-XX:HeapDumpPath=/opt/DDT/CPA-XX:-omitstacktraceinfasttrow
内存:
自由-m
缓存的可用共享缓冲区总数
内存:64298 37022 27275 5 593 9466
-/+缓冲区/缓存:269623736
交换:15847 957 14889
系统限制:
乌利米特-a
核心文件大小(块,-c)0
数据段大小(kbytes,-d)不受限制
调度优先级(-e)0
文件大小(块,-f)不受限制
挂起信号(-i)256455
最大锁定内存(KB,-l)64
最大内存大小(kbytes,-m)不受限制
打开文件(-n)64000
管道大小(512字节,-p)8
POSIX消息队列(字节,-q)819200
实时优先级(-r)0
堆栈大小(kbytes,-s)8192
cpu时间(秒,-t)无限制
最大用户进程(-u)256455
虚拟内存(KB,-v)不受限制
文件锁定(-x)不受限制
最佳答案
我认为64位虚拟机和压缩OOPS可能会面临以下问题:
https://bugs.openjdk.java.net/browse/JDK-8187709
https://blogs.oracle.com/poonam/running-on-a-64bit-platform-and-still-running-out-of-memory
关于java - 高负载项目中的Java OOM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48457796/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!