1.内存泄露:
Java的内存泄漏是指某些对象不再被应用程序使用,而垃圾收集器(Garbage Collector)却没能识别它们是“不再使用的”,所以没有对这些对象进行回收,或者由于某些原因无法回收或者回收不彻底!
举例:
-
各种连接,比如数据库连接(dataSourse.getConnection()),网络连接(socket)和io连接,除非其显式的调用了其close()方法将其连接关闭,否则是不会自动被GC 回收的。
-
静态集合类没有被释放-对象没有被释放
-
递归调用层次太多
如果那些不使用的对象占用堆(heap)空间足够大,使得应用程序无法满足下一次内存分配需求,就会导致OutOfMemoryError错误。
内存泄漏和系统超负荷两者是有区别的,虽然可能导致的最终结果是一样的。
内存泄漏是用完的资源没有回收引起错误,而系统超负荷则是系统确实没有那么多资源可以分配了(其他的资源都在使用)。
内存泄漏可以通过软件调优来解决,系统超负荷则只能通过更新硬件来解决。
2.内存泄漏的表现
—内存快被占满,但还没被占满,处于临界点,这时候不会有报错,但会影响性能
—日志里明确产生OOM等错误。比如,下图,回落点连起来基本水平则表示正常回收,反之回收不彻底。
3.内存泄露的排查思路:
—–JVM和GC的关键参数设置(比如,-Xms -Xmx等都没有设置,那么可能会出现内存泄露)
—–排查代码
4.OutOfMemory常见类型
—-堆空间被占满:https://blog.51cto.com/11009785/2382260
—-永久代/元空间被占满:https://blog.51cto.com/11009785/2379670
—-栈溢出:java.lang.stackoverflowerror;fatal:stack size too small
排查:先看参数-Xss:每个线程的栈大小,用于保存函数调用、返回地址等,默认1M,如果报错,改为2M,如果还不行,捕获快照,去排查代码,有可能是递归调用的层次太多了。
—-系统内存被占满:java.lang.outofmemoryerror:unable to create new native thread
解决:升级硬件
5.java.lang.OutOfMemoryError错误的可能原因,及排查思路:
—空间不足
—首先排查是不是硬件方面的问题
—如果硬件不错,再排查参数,是不是设置的小了
—内存泄漏
—如果硬件和参数都没问题,那么怀疑是内存泄露,需要排查JVM和GC的参数设置,如果还不行,需要排查代码
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/194449.html