OOM三种类型
OOM的三种类型:
堆OOM
/**
* -Xmx1g -XX:+PrintGCDetails -XX:MaxDirectMemorySize=100m
*
* @param args
*/
public static void main(String[] args) {
ArrayList<byte[]> arrayList = new ArrayList<>();
for (int i = 0; i < 1024; i++) {
arrayList.add(new byte[1024 * 1024 * 2]);
}
}
运行结果:
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space at com.Test.main(Test.java:15)
解决方法: 增大Xmx值 使用MAT,JProfile等工具进行代码分析与优化
直接内存OOM
/**
* -Xmx1g -XX:+PrintGCDetails -XX:MaxDirectMemorySize=100m
* @param args
*/
public static void main(String[] args) {
for (int i = 0; i < 2048; i++) {
ByteBuffer.allocateDirect(1024 * 1024*2);
System.out.println(i);
//System.gc();
}
}
运行结果: 直接内存设置为2M,超过100M时,进行回收
解决方法: 增大MaxDirectMemorySize的值
过多线程导致的OOM
/**
* -Xmx1g -XX:+PrintGCDetails
-XX:MaxDirectMemorySize=100m
-Xss:指定栈空间大小
*
* @param args
*/
public static void main(String[] args) {
for (int i = 0; i <1500 ; i++) {
new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
}
运行结果: OOM unable to create native thread
解决方法: 减少线程数、或减少堆空间与线程空间
永久(Pern)溢出
永久区是存储类元数据的区域
/**
* -Xmx1g -XX:+PrintGCDetails
*
* @param args
*/
public static void main(String[] args) {
for (int i = 0; i < 1000000000; i++) {
Integer integer = new Integer("1" + new StringBuffer(1));
System.out.println(new ArrayList<>());
}
}
运行结果: OOM Permgen sace 解决方法:
- 增大MaxPremSize的值
- 减少系统需要的类的数量
- 使用ClassLoader合理装载类,并进行回收
GC效率低下引起的OOM
判断GC引起OOM的条件
- 花在GC上的时间是否超过了98%
- 老年代释放的内存是否小于2%
- Eden区释放的内存是否小于2%
- 是否连续5次GC都出现了上述几种情况
关闭OOM可以通过参数:-XX:-UseGCOverheadLimit 进行设置
String常量池因其的OOM
/**
* -Xmx5m -XX:MaxPermSize5m【JDK<1.6】
*
* @param args
*/
public static void main(String[] args) {
List<String> list = new ArrayList<>();
int i = 0;
while (true) {
list.add(String.valueOf(i++).intern());
}
}
运行结果: JDK1.6 :Perm space JDK1.7 :heap space
【注】
/**
*String.intern()方法返回字符串常量池引用,但不一定每时每刻都返回一样,可能垃圾回收后重新放入常量池
*
* @param args
*/
public static void main(String[] args) {
System.out.println(System.identityHashCode((args[0] + Integer.toString(0))));//字符本身hash
System.out.println(System.identityHashCode((args[0] + Integer.toString(0)).intern()));//常量池引用
System.gc();//未gc前常量池引用相同
System.out.println(System.identityHashCode((args[0] + Integer.toString(0)).intern()));//常量池引用
}
浅堆和深堆
浅堆(shallow heap):一个对象结构所占的内存大小,对象包括属性和对象头、对象引用等。
如String对象,其结构包括:
| 类型 | 值 | 大小 |
|---|---|---|
| int | hash32 | 0 |
| int | hash | 0 |
| ref | value | c://... |
其中2个int8字节 对象引用4字节 对象头8字节 按照8字节对齐,则对象浅堆共24字节
深堆(retained heap):一个对象被GC回收后,可以真实释放的内存大小。即对象所持有的对象和包括对象自身的所有的浅堆的大小之和。
从图中可以看出对象A的浅堆大小为A本身,对象A的实际大小为对象A、对象B、对象C、对象D的浅堆大小之和,对象A的深堆大小为对象A和对象C,因为对象B和对象D同时也被对象E所引用
OOM三种类型的更多相关文章
- 链路层三种类型的MAC地址
若需要转载,请注明出处. 我们知道,链路层都是以MAC地址来进行通信双方的地址标识的,如下图:在应用中根据接收方的多寡来进行划分,可分为以下三种: 单播(Unicast) 多播(Multicast) ...
- matlab for循环的三种类型
学习了一半了,发现一个好网站,就是我想写这篇博客用的,网络真是个好东西!纪念下国庆啦 网址:http://www.yiibai.com/matlab/matlab_for_loop.html ---- ...
- C# enum、int、string三种类型互相转换
enum.int.string三种类型之间的互转 #代码: public enum Sex { Man=, Woman= } public static void enumConvert() { in ...
- 缓慢变化维 (Slowly Changing Dimension) 常见的三种类型及原型设计(转)
开篇介绍 在从 OLTP 业务数据库向 DW 数据仓库抽取数据的过程中,特别是第一次导入之后的每一次增量抽取往往会遇到这样的问题:业务数据库中的一些数据发生了更改,到底要不要将这些变化也反映到数据仓库 ...
- ASP.NET 设计模式分为三种类型
设计模式分为三种类型,共23类. 一.创建型模式:单例模式.抽象工厂模式.建造者模式.工厂模式.原型模式. 二.结构型模式:适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代 ...
- 云计算服务的三种类型(SaaS、PaaS、IaaS)
云计算可以帮助企业降低IT方面的成本和复杂性,并获得他们蓬勃发展所需的灵活性与敏捷性.但是,规划出通往云的明确路径并非易事.毕竟用户需要看透与云相关的市场大肆宣传,然后理解并分析不同种类的云计算模式的 ...
- Kubernetes service 三种类型/NodePort端口固定
Kubernetes service 三种类型 • ClusterIP:默认,分配一个集群内部可以访问的虚拟IP(VIP)• NodePort:在每个Node上分配一个端口作为外部访问入口• Load ...
- 留学英文论文写作Abstract三种类型
所谓Abstract,就是对所写论文主要内容的精炼概括.Abstract是美国人的说法,英国的科技期刊喜欢称之为Summary.在英文中,有资料是这么对其定义的:Abstract is a sketc ...
- spring-cloud-square开发实战(三种类型全覆盖)
欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇概览 前文<五分钟搞懂spring-clou ...
随机推荐
- Vmware在NAT模式下网络配置详解
Vmware在NAT模式下网络配置详解 Linux中的网络配置对于接触Linux不久的小白菜来说,还是小有难度的,可能是不熟悉这种与windows系列迥然不同的命令行操作,也可能是由于对Linux的结 ...
- python爬虫14 | 就这么说吧,如果你不懂python多线程和线程池,那就去河边摸鱼!
你知道吗? 在我的心里 你是多么的重要 就像 恩 请允许我来一段 freestyle 你们准备好了妹油 你看 这个碗 它又大又圆 就像 这条面 它又长又宽 你们 在这里 看文章 觉得 很开心 就像 我 ...
- Maven pom 配置简介
1. groupId artifactId version 2. dependencies 3. plugins http://shmilyaw-hotmail-com.iteye.com/blog/ ...
- 3 Java的基本程序设计结构
本章主要内容: 一个简单的Java应用程序 注释 数据类型 变量 运算符 字符串 输入输出 控制流 大数值 数组 本章主要介绍程序设计的基本概念(如数据类型.分支以及循环)在Jav ...
- C#关键字详解第一节
abstract:抽象类: 他表达对问题或者实际中的事物,对象等所设计出的抽象概念,比如一个灵感.生物等,这些都是抽像, 但是他们往往也有具体的指向,比如生物圈有人类,猴子,老虎等等,老虎和人类是实际 ...
- (42)Spring Boot多数据源【从零开始学Spring Boot】
我们在开发过程中可能需要用到多个数据源,我们有一个项目(MySQL)就是和别的项目(SQL Server)混合使用了.其中SQL Server是别的公司开发的,有些基本数据需要从他们平台进行调取,那么 ...
- hdu 4081 最小生成树变形
/*关于最小生成树的等效边,就是讲两个相同的集合连接在一起 先建立一个任意最小生成树,这条边分开的两个子树的节点最大的一个和为A,sum为最小生成树的权值和,B为sum-当前边的权值 不断枚举最小生成 ...
- js两个整数之间求和
const GetSum = (a, b) => { let min = Math.min(a, b), max = Math.max(a, b); return (max - min + 1) ...
- N天学习一个Linux命令之top
用途 查看机器负载以及进程资源占用情况,linux系统性能分析工具 用法 top -hv | -abcHimMsS -d delay -n iterations -p pid [, pid ...] ...
- [转]十五天精通WCF——终结篇 那些你需要注意的坑
终于一路走来,到了本系列的最后一篇了,这一篇也没什么好说的,整体知识框架已经在前面的系列文章中讲完了,wcf的配置众多,如果 不加一些指定配置,你可能会遇到一些灾难性的后果,快来一睹为快吧. 一: 第 ...