当前位置: 首页 > news >正文

洛阳网站设计开发哪家建设公司网站

洛阳网站设计开发,哪家建设公司网站,linux wordpress安装,偃师做网站问题来源 一次生产事故,由于一次性从数据库查询过多数据导致线程 OOM:Java heap space 异常(千万级表,JVM堆内存2G),但是在线程OOM发生时,java进程却没有立即挂掉。 ##OOM与异常 说到底OutOfM…

问题来源

一次生产事故,由于一次性从数据库查询过多数据导致线程 OOM:Java heap space 异常(千万级表,JVM堆内存2G),但是在线程OOM发生时,java进程却没有立即挂掉。

##OOM与异常
说到底OutOfMemoryError也只是一个java中的异常而已,属于Error一系非检查异常:

ObjectThrowableErrorVirtualMachineErrorOutOfMemoryError

堆内存不够与异常的关系

线程发生OOM Java heap space,首先是堆空间不够了,然后再由jvm在申请分配空间的方法调用上抛出OOM异常。
对于线程,它会像处理普通异常一样,处理OutOfMemoryError。

实例

package org.example;import com.sun.javafx.scene.control.skin.TableHeaderRow;import java.util.ArrayList;//TIP To <b>Run</b> code, press <shortcut actionId="Run"/> or
// click the <icon src="AllIcons.Actions.Execute"/> icon in the gutter.
public class Main {public static void main(String[] args) throws InterruptedException{//TIP Press <shortcut actionId="ShowIntentionActions"/> with your caret at the highlighted text// to see how IntelliJ IDEA suggests fixing it.System.out.printf("Hello and welcome!");System.out.println("JVM从OS获取的 最大 内存" + Runtime.getRuntime().maxMemory() / 1024 / 1024 + "M");System.out.println("JVM从OS获取的 当前 内存" + Runtime.getRuntime().totalMemory() / 1024 / 1024 + "M");System.out.println("JVM从OS获取的 但空闲 内存" + Runtime.getRuntime().freeMemory() / 1024 / 1024 + "M");// 创建线程new Thread(() -> {ArrayList<byte[]> bytes = new ArrayList<>();for (int i = 0; i < 2000; i++) {byte[] bytes1 = new byte[3 * 1024 * 1024];bytes.add(bytes1);System.out.println(Thread.currentThread().getName()+":JVM从OS获取的 当前 内存" + Runtime.getRuntime().totalMemory() / 1024 / 1024 + "M");}}).start();// 创建线程new Thread(() -> {ArrayList<byte[]> bytes = new ArrayList<>();for (int i = 0; i < 2000; i++) {byte[] bytes1 = new byte[3 * 1024 * 1024];bytes.add(bytes1);System.out.println(Thread.currentThread().getName()+":JVM从OS获取的 当前 内存" + Runtime.getRuntime().totalMemory() / 1024 / 1024 + "M");}}).start();while (true){System.out.println(Thread.currentThread().getName() + " continuing...");Thread.sleep(1000L);}}
}

结果:

##本机64位,16G内存,默认最大堆3600M
JVM从OS获取的 最大 内存3600M
JVM从OS获取的 当前 内存243M
JVM从OS获取的 但空闲 内存237M
main continuing...##2个线程分别开始创建byte数组,占用内存 
Thread-0:JVM从OS获取的 当前 内存307M
Thread-1:JVM从OS获取的 当前 内存307M
Thread-1:JVM从OS获取的 当前 内存307M
Thread-0:JVM从OS获取的 当前 内存307M##JVM增长到极限,Thread-1先报OOM
Thread-0:JVM从OS获取的 当前 内存3366M
Thread-0:JVM从OS获取的 当前 内存3366M
Exception in thread "Thread-1" java.lang.OutOfMemoryError: Java heap spaceat org.example.Main.lambda$main$1(Main.java:39)at org.example.Main$$Lambda$2/1828972342.run(Unknown Source)at java.lang.Thread.run(Thread.java:750)
Thread-0:JVM从OS获取的 当前 内存3366M
Thread-0:JVM从OS获取的 当前 内存3366M#Thread-1失败终止后,起引用的对象也就可以GC了,Thread-0又获取了好多内存,直到OOM
Thread-0:JVM从OS获取的 当前 内存3616M
Thread-0:JVM从OS获取的 当前 内存3616M
Exception in thread "Thread-0" java.lang.OutOfMemoryError: Java heap spaceat org.example.Main.lambda$main$0(Main.java:29)at org.example.Main$$Lambda$1/1989780873.run(Unknown Source)at java.lang.Thread.run(Thread.java:750)
main continuing...
main continuing...
main continuing...

结论

1、OOM是在线程上发生的,会被当做一般异常处理,不会导致JVM的退出;
2、多线程公用JVM,一个线程终止GC后,内存重新给其他线程分配。

http://www.ds6.com.cn/news/24487.html

相关文章:

  • dw做网站banner长沙网站推广
  • 汕头企业网站网络营销公司如何建立
  • 活动策划网站源码百度seo营销推广
  • 福建省城乡和建设厅网站深圳全网推互联科技有限公司
  • 做张家界旅游网站多少钱可口可乐软文范例
  • 焦作网站建设哪家专业网站宣传方式有哪些
  • 外贸建站推广多少钱安徽seo团队
  • 地方政府网站建设中存在的问题360推广官网
  • 网站的盈利方式谷歌seo怎么优化
  • 网站建设轮播图游戏代理平台哪个好
  • 厦门建设工程招标中心的网站网站建设设计
  • 北京免费网站制作百度收录量查询
  • 网站建设的发票怎么做会计分录淘宝关键词搜索排行榜
  • 邵阳今日头条新闻sem和seo的关系
  • 建网站算法购物网站推广方案
  • logo设计竞标网站廊坊快速优化排名
  • 一起做网店网站打不开百度广告一天多少钱
  • 专业网站建设软件开发百度信息流广告怎么投放
  • 大连响应式网站制作seo优化的优点
  • 源代码 培训 网站seo优化网站百度技术
  • 台州网站建设技术支持长沙网络营销推广公司
  • 政务网站建设情况汇报百度指数介绍
  • 电子商务网站开发方式sem代运营公司
  • 山东省建设厅的网站营销推广网
  • 聊天网站制作教程重庆seo推广
  • xblog wordpress广州网站优化运营
  • 如何编写一个app关键词优化包含
  • 自己怎样建立个人网站怎样注册一个自己的平台
  • 创新网站建设工作室计算机基础培训机构
  • 万博法务网站网络推广公司加盟