📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)清华大学出版社签约作家、Java领域优质创作者、优快云博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。
📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、SpringMVC、SpringCloud、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RocketMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。不定期分享高并发、高可用、高性能、微服务、分布式、海量数据、性能调优、云原生、项目管理、产品思维、技术选型、架构设计、求职面试、副业思维、个人成长等内容。
🌾阅读前,快速浏览目录和章节概览可帮助了解文章结构、内容和作者的重点。了解自己希望从中获得什么样的知识或经验是非常重要的。建议在阅读时做笔记、思考问题、自我提问,以加深理解和吸收知识。阅读结束后,反思和总结所学内容,并尝试应用到现实中,有助于深化理解和应用知识。与朋友或同事分享所读内容,讨论细节并获得反馈,也有助于加深对知识的理解和吸收。💡在这个美好的时刻,笔者不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。
一、JVM知识体系
-
类加载机制
- 类加载机制是JVM的核心功能之一,它确保了Java代码的运行安全性和稳定性。在类加载过程中,JVM会执行一系列的步骤,包括加载、验证、准备和初始化。
- 加载阶段,JVM通过类加载器找到并加载指定的
.class文件,将其转化为Class对象。这个过程中,类加载器会检查类文件是否被非法修改,确保其完整性和安全性。 - 验证阶段,JVM会检查类文件的结构是否正确,确保类文件中的字节码指令不会违反Java语言规范,防止潜在的运行时错误。
- 准备阶段,JVM为类变量分配内存,并设置默认初始值。这个过程不会涉及到类的实例化对象,因此不会执行构造器方法。
- 初始化阶段,JVM执行类构造器方法
<clinit>(),这个过程会初始化类变量,并执行静态代码块中的代码。
-
双亲委派模型
- 双亲委派模型要求类加载器首先委托其父类加载器尝试加载类,只有当父类加载器无法加载时,子类加载器才会尝试从自己的资源路径中加载。
- 这种模型保证了类型的安全性和命名空间的隔离,防止不同类加载器加载相同名称但实际不同的类。
-
自定义类加载器
- 自定义类加载器允许开发者实现特定的加载逻辑,比如从特定的资源路径加载类,或者实现特定的类加载策略。
- 开发者可以通过继承
ClassLoader类,并重写findClass方法来实现自定义的类加载逻辑。
-
模块化系统(JPMS)
- Java Platform Module System(JPMS)是Java 9引入的模块化系统,它将Java程序分解为多个模块,每个模块都定义了其依赖关系和接口。
- JPMS通过模块描述文件(
module-info.java)来声明模块的依赖和提供的接口,从而实现了模块的独立性和可复用性。
-
内存模型
- JVM的内存模型是JVM运行时环境的基础,它定义了内存的布局和访问规则。
- 堆是JVM内存中最大的部分,用于存储所有的类实例和数组对象。堆空间是动态分配的,垃圾回收主要发生在堆上。
- 栈是线程私有的内存区域,用于存储局部变量和方法调用的上下文。栈空间的大小通常在创建线程时确定,且不会像堆那样容易溢出。
- 方法区存储已被虚拟机加载的类信息、常量、静态变量等数据。它类似于永久代,但在Java 8及以后的版本中,方法区与堆合并为一个区域。
-
内存溢出场景分析
- 内存溢出通常发生在堆内存和栈内存不足的情况下。堆内存溢出可能是因为创建了大量的对象,或者存在内存泄漏。
- 栈内存溢出通常是因为方法调用深度过大,或者递归调用过于频繁。
-
垃圾回收
- 垃圾回收是JVM自动管理内存的重要机制,它通过回收不再使用的对象来释放内存。
- GC Roots可达性分析是垃圾回收的核心算法之一,它从GC Roots开始,向上遍历可达的对象,不可达的对象将被回收。
- 分代收集理论将对象分为新生代和老年代,分别采用不同的回收策略,以提高垃圾回收的效率。
-
垃圾回收算法
- 标记-清除算法是最传统的垃圾回收算法,它分为标记和清除两个阶段,但存在内存碎片化的问题。
- 复制算法将内存分为两个部分,每次只使用其中一部分,当这部分内存用完时,将存活的对象复制到另一部分,但需要额外的空间。
- 整理算法是在复制算法的基础上进行内存整理,以提高内存利用率。
-
并发收集器
- 并发收集器允许垃圾回收与应用程序的运行同时进行,以减少应用程序的停顿时间。
- CMS(Concurrent Mark Sweep)收集器通过并发标记和清除来减少停顿时间,适用于对响应时间要求较高的场景。
- G1(Garbage-First)收集器基于Region的区域划分,优先回收垃圾回收价值最高的区域,适用于大内存场景。
- ZGC(Z Garbage Collector)是一种低延迟的垃圾回收器,适用于对响应时间要求极高的场景。
-
停顿时间控制策略
- JVM提供了多种停顿时间控制策略,如最大停顿时间、目标停顿时间等,以优化垃圾回收的性能。
-
性能调优
- JVM参数配置是性能调优的重要手段,通过调整JVM的启动参数(如堆大小、垃圾回收策略等)来优化性能。
- 内存泄漏诊断是性能调优的另一个重要方面,通过分析内存使用情况,找出并修复内存泄漏问题。
-
JIT编译优化
- JIT(Just-In-Time)编译器是JVM的性能优化引擎,它将Java字节码编译成本地机器码,以提高程序的执行效率。
- JIT编译器通过静态分析、动态编译和即时优化等技术,实现对Java代码的高效执行。
二、Spring Boot知识体系
-
自动配置
- Spring Boot的自动配置功能是基于条件化配置实现的,它会根据项目依赖自动配置Spring框架和相关库。
- 自动配置的核心是
@EnableAutoConfiguration注解,它会扫描类路径下的配置类,并根据条件自动配置所需的Bean。
-
@EnableAutoConfiguration原理
@EnableAutoConfiguration注解通过SpringFactoriesLoader类加载类路径下META-INF/spring.factories文件中的配置类。- 这些配置类通常以
org.springframework.boot.autoconfigure.EnableAutoConfiguration为键,以自动配置类的全限定名作为值。
-
条件化配置(@Conditional)
@Conditional注解可以基于特定的条件,有选择地应用配置。- 例如,
@ConditionalOnClass注解可以指定当存在某个类时才应用配置,@ConditionalOnMissingBean注解可以指定当不存在某个Bean时才应用配置。
-
自定义Starter开发
- 自定义Starter可以帮助开发者快速集成Spring Boot应用。
- 开发者可以通过创建一个Maven或Gradle项目,添加必要的依赖和自动配置类,然后将其打包成Starter。
-
起步依赖
- 起步依赖是Spring Boot的核心依赖,它包含Spring框架和相关库。
- 起步依赖简化了Spring Boot应用的构建过程,开发者只需添加起步依赖,即可快速开始开发。
-
依赖管理机制
- Spring Boot使用Maven或Gradle作为构建工具,通过
pom.xml或build.gradle文件进行依赖管理。 - 依赖管理机制可以自动处理依赖之间的版本冲突,并确保应用程序的依赖关系一致。
- Spring Boot使用Maven或Gradle作为构建工具,通过
-
版本冲突解决
- 版本冲突是依赖管理中常见的问题,可以通过使用BOM(Bill of Materials)文件或指定依赖的版本来解决。
-
第三方库集成模式
- Spring Boot支持多种第三方库集成模式,如starter依赖、配置文件、注解等。
- 开发者可以根据具体需求选择合适的集成方式。
-
Actuator
- Spring Boot Actuator提供了一系列端点,用于监控和管理Spring Boot应用程序。
- 这些端点可以提供应用程序的运行时信息,如内存使用情况、线程信息、HTTP请求统计等。
-
健康检查端点
- 健康检查端点用于检查应用程序是否正常运行。
- 开发者可以通过自定义健康指标,来提供更详细的健康检查信息。
-
度量指标收集
- Spring Boot Actuator支持收集应用程序的度量指标,如内存使用情况、线程信息等。
- 这些度量指标可以通过Micrometer进行监控和可视化。
-
自定义Endpoint开发
- 用户可以自定义Endpoint,以扩展Actuator的功能。
- 自定义Endpoint可以通过实现
Endpoint接口或使用@Endpoint注解来实现。
-
配置文件管理
- Spring Boot支持多环境配置,通过
application-{profile}.yml文件实现。 - 开发者可以根据不同的环境(如开发、测试、生产)配置不同的应用程序参数。
- Spring Boot支持多环境配置,通过
-
配置加载优先级
- Spring Boot按照优先级加载配置文件,如
application.yml、application-{profile}.yml等。 - 应用程序会首先加载
application.yml,然后根据配置文件中指定的spring.profiles.active值加载相应的配置文件。
- Spring Boot按照优先级加载配置文件,如
-
动态配置刷新
- Spring Boot支持动态刷新配置,以实现热部署。
- 开发者可以通过Actuator的
/actuator/refresh端点来刷新应用程序的配置。
-
监控与日志
- Spring Boot集成Micrometer进行监控,集成Logback/SLF4J进行日志配置。
- Micrometer支持多种监控工具,如Prometheus、Grafana等。
- Logback/SLF4J提供灵活的日志配置和格式化功能。
-
分布式链路追踪
- Spring Boot支持分布式链路追踪,如Zipkin、Jaeger等。
- 分布式链路追踪可以帮助开发者追踪请求在分布式系统中的执行路径,并分析性能瓶颈。
-
扩展机制
- Spring Boot提供多种扩展机制,如自定义AutoConfiguration、Bean生命周期扩展点等。
- 开发者可以通过实现这些扩展机制,来定制化Spring Boot应用程序的行为。
-
响应式编程支持
- Spring Boot支持响应式编程,如Spring WebFlux等。
- 响应式编程可以提供更好的并发性能和可扩展性。
📥博主的人生感悟和目标
- 💂 博客主页: Java程序员廖志伟希望各位读者大大多多支持用心写文章的博主,现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!
- 👉 开源项目: Java程序员廖志伟
- 🌥 哔哩哔哩: Java程序员廖志伟
- 🎏 个人社区: Java程序员廖志伟
- 🔖 个人微信号:
SeniorRD
📙经过多年在优快云创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续出版。这些书籍包括了基础篇、进阶篇、架构篇的📌《Java项目实战—深入理解大型互联网企业通用技术》📌,以及📚《解密程序员的思维密码--沟通、演讲、思考的实践》📚。具体出版计划会根据实际情况进行调整,希望各位读者朋友能够多多支持!
🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~
471

被折叠的 条评论
为什么被折叠?



