Java 谈谈你对OOM的认识

文章目录

  • 前言
  • 一、基础架构
  • 二、常见OOM
    • 1、栈内存溢出java.lang.StackOverflowError
    • [2、堆内存溢出java.lang.OutOfMemoryError:Java heap space](#2、堆内存溢出java.lang.OutOfMemoryError:Java heap space)
    • [3、GC回收时间过长java.lang.OutOfMemoryError: GC overhead limit exceeded](#3、GC回收时间过长java.lang.OutOfMemoryError: GC overhead limit exceeded)
    • [4、NIO程序堆外内存溢出java.lang.OutOfMemoryError: Direct buffer memory](#4、NIO程序堆外内存溢出java.lang.OutOfMemoryError: Direct buffer memory)
    • [5、(重要)不能创建本地线程java.lang.OutOfMemoryError: unable to create native thread](#5、(重要)不能创建本地线程java.lang.OutOfMemoryError: unable to create native thread)
    • [6、元空间溢出java.lang.OutOfMemoryError: Metaspace](#6、元空间溢出java.lang.OutOfMemoryError: Metaspace)

前言

对OOM部分的认识,予以记录!

一、基础架构

Error与Exception

二、常见OOM

1、栈内存溢出java.lang.StackOverflowError

方法的递归调用

java 复制代码
public class StackOverFlowErrorDemo {
    public static void main(String[] args) {
        stackOverFlowError();
    }

    private static void stackOverFlowError() {
        stackOverFlowError();
    }
}

2、堆内存溢出java.lang.OutOfMemoryError:Java heap space

new大对象

java 复制代码
public class HeapSpaceDemo {
    public static void main(String[] args) {
        byte[] bytes = new byte[30 * 1024 * 1024];
    }
}


3、GC回收时间过长java.lang.OutOfMemoryError: GC overhead limit exceeded

超过98%的时间做GC而回收了不到2%的堆内存

java 复制代码
public class GCOverheadDemo {
    public static void main(String[] args) {
        int i = 0;
        List<String> list = new ArrayList<>();

        try {
            while (true) {
                list.add(String.valueOf(++i).intern());
            }
        } catch (Throwable e) {
            System.out.println("=================" + i);
            e.printStackTrace();
            throw e;
        }
    }
}

4、NIO程序堆外内存溢出java.lang.OutOfMemoryError: Direct buffer memory

netty nio

java 复制代码
public class DirectBufferMemoryDemo {
    public static void main(String[] args) {
        System.out.println("配置的maxDirectoryMemory:" + (sun.misc.VM.maxDirectMemory() / (double)1024 / 1024) + "MB");

        ByteBuffer byteBuffer = ByteBuffer.allocateDirect(6 * 1024 * 1024);
    }
}

5、(重要)不能创建本地线程java.lang.OutOfMemoryError: unable to create native thread

java 复制代码
package com.kqli.oom;

public class UnableCreateNewThreadDemo {
    public static void main(String[] args) {
        for (int i = 0; ; i++) {
            System.out.println("=========" + i);
            new Thread(() -> {
                try {
                    Thread.sleep(Integer.MAX_VALUE);
                } catch (InterruptedException e) {
                    throw new RuntimeException(e);
                }

            }, "Thread-" + i).start();

        }
    }
}

将java文件复制到ubuntu中,执行以下命令:

shell 复制代码
javac -d . UnableCreateNewThreadDemo.java

java com.kqli.oom.UnableCreateNewThreadDemo

6、元空间溢出java.lang.OutOfMemoryError: Metaspace

相关推荐
冷雨夜中漫步6 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴7 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再7 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
JH30737 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
m0_736919108 小时前
C++代码风格检查工具
开发语言·c++·算法
喵手8 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
Coder_Boy_8 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
2501_944934738 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy9 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
invicinble9 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat