Docker步步实践
目录文档:
①Docker简介
②基本概念
③安装Docker
④使用镜像:
⑤操作容器:
⑥访问仓库:
⑦数据管理:
⑧使用网络:
⑨高级网络配置:
⑩安全:
⑪底层实现:
⑫其他项目:
基本上,您可以在堆中看到与 Java OutOfMemoryError 问题相关的三个不同问题区域:
-
仍然具有GC根引用但从未在应用程序代码中使用的对象。这是 Java内存泄漏 。
-
对象太多或太大。意味着没有足够的堆可用于执行应用程序,因为内存中保存了太大的对象树(例如缓存)。
-
临时对象太多。意味着Java代码中的处理暂时需要太多内存。
============================================================================
当对象仍然具有GC根引用,但在应用程序中不再使用时,就会产生Java内存泄漏。这些“游荡对象”证明了JVM内存的完整持续时间。如果在应用程序逻辑中连续创建这样的“对象体”,典型的问题子对象是静态集合,它们被用作一种缓存。 add() 和 remove() 方法在这里使用的频率是多少。添加的对象被静态集合项引用,并且由于GC根引用(static)而不能再释放。
在内存泄漏的上下文中,也经常提到所谓的支配者或支配树。
支配者的概念来源于图论,当一个节点只能到达另一个节点时,它就被定义为另一个节点的支配者。因此,当没有其他对象C引用B时,对象A是另一个对象B的支配者。支配者树则是一个子树,其中来自根节点的条件应用于所有子节点。如果根引用被释放,整个支配树将被释放。因此,在内存泄漏搜索中,非常大的控制树是非常好的候选。
根据不再需要的对象的生成频率和大小,以及Java堆的配置大小,OutOfMemoryError迟早会发生。正是后一种变体,即所谓的“爬行内存泄漏”,在许多应用程序中都会发现,而且这些问题通常会被“忽略”,并且会遇到以下措施:
更大的堆来争取时间,直到错误发生。不幸的是,在64位jvm时代,这种方法正变得越来越流行。
晚上重启应用服务器。这将导致内存重置。如果内存在24小时内没有完全填满,可以通过重新启动来避免错误。
这两个版本都是危险的,因为它们对性能有负面影响,并且有可能由于用户行为的改变或更多的通信量而导致错误比预期更快地发生。性能也受到垃圾收集器的负面影响,因为越来越满的“终身生成”意味着GC必须经历更多的对象,“标记”阶段需要越来越多的时间,随着大量堆,要分析的对象的数量变得更大。因此,本系列文章将详细分析这些内存泄漏,以避免出现这种情况。
========================================================================
还有一些情况下,堆中的OutOfMemoryError不是由实际意义上的内存泄漏引起的,而是应用程序消耗了太多内存。在这种情况下,要么选择的堆太小,必须将其放大,要么必须减少应用程序的内存消耗,例如选择较小的缓存大小。
然而,临时存储的高消耗也特别重要,因为它会导致某些并行访问应用程序中发生OutOfMemoryError,因此这些应用程序是不确定的,因此会造成更大的不适,因为你不能在晚上重新开始。以下示例显示了可能的问题代码:
byte[] image = getTheByteImage();
response.setContentType(“image/jpeg”);
ServletOutputStream out = response.getOutputStream();
out.write(image);
out.flush();
out.close();
内存消耗在这里并不明显,但是,图像在每次调用时都作为字节数组放在堆上,然后再发送到浏览器。更好的选择是直接简化图像:
InputStream image = getTheImageAsStream();
response.setContentType(“image/jpeg”);
ServletOutputStream out = response.getOutputStream();
IOUtils.copy(image, out);
out.flush();
out.close();
( BufferedStreams 和 ioutil 在内部使用 byte ,但它们通常要小得多)
在这方面,我们第一次只有 java.lang.OutOfMemoryError 错误说明堆中的问题。
在本系列的下一部分“Java虚拟机的配置和监视”中,我将向您展示如何在sun jvm上配置和优化堆设置,以及如何使用JVM资源监视内存。
因此,接下来的两个部分将更实际,而不是理论性的,我计划整合一些小屏幕截图来给出说明性的例子。
有一些有趣的场景,引用不再可访问,但内存无法释放,例如:
public void someMethod() {
try {
String xml = getSomeBigXML();
// do something
} catch (AnException) {
// handle exception
}
学习分享,共勉
这里是小编拿到的学习资源,其中包括“中高级Java开发面试高频考点题笔记300道.pdf”和“Java核心知识体系笔记.pdf”文件分享,内容丰富,囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。同时还有Java进阶学习的知识笔记脑图(内含大量学习笔记)!
资料整理不易,读者朋友可以转发分享下!
Java核心知识体系笔记.pdf
中高级Java开发面试高频考点题笔记300道.pdf
架构进阶面试专题及架构学习笔记脑图
Java架构进阶学习视频分享
阶学习视频分享**