📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)、《解密程序员的思维密码——沟通、演讲、思考的实践》作者、清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。
📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、SpringMVC、SpringCloud、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RocketMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。
📙不定期分享高并发、高可用、高性能、微服务、分布式、海量数据、性能调优、云原生、项目管理、产品思维、技术选型、架构设计、求职面试、副业思维、个人成长等内容。
💡在这个美好的时刻,笔者不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。
一、IoC容器核心依赖注入实现
控制反转(IoC)是Spring框架的核心概念之一,它通过将对象的创建和生命周期管理交给Spring容器,降低了对象之间的耦合度。下面将详细解析IoC容器的核心依赖注入实现。
1. 构造器注入
构造器注入是依赖注入的一种方式,通过调用类的构造器来注入依赖。这种方式要求依赖注入的属性必须在类的构造器中定义,确保对象在实例化时依赖关系得到满足。
技术实现细节:
- Spring容器在创建对象实例时,会检查类的构造器参数是否已经被注入。
- 如果没有注入,Spring容器将尝试查找相应的Bean,并注入到构造器参数中。
- 这种方式适用于依赖关系明确的场景,但可能会导致构造器参数过多,影响代码可读性。
2. Setter注入
Setter注入是另一种依赖注入的方式,通过调用类的setter方法来注入依赖。这种方式比构造器注入更灵活,即使类中没有构造器,也可以使用setter注入。
技术实现细节:
- Spring容器通过反射查找类的setter方法,并注入相应的依赖。
- 这种方式允许在运行时动态改变对象的依赖关系,增加了系统的灵活性。
- Setter注入通常与Java的Bean规范一起使用,确保setter方法遵循一定的命名规则。
3. 字段注入
字段注入是通过直接在类中声明依赖对象来实现的。在Spring 3.0之后,字段注入被弃用,因为它可能会导致性能问题。
技术实现细节:
- 字段注入依赖于Spring容器的反射机制,直接将依赖对象注入到类的字段中。
- 这种方式在Spring 3.0之前较为常见,但由于性能问题,逐渐被setter注入取代。
4. 方法注入
方法注入是通过定义特定的方法来注入依赖的。这种方式在Spring中很少使用,因为它增加了代码的复杂性。
技术实现细节:
- 方法注入需要定义特定的注入方法,并在方法中注入依赖。
- 这种方式通常用于复杂的依赖注入场景,如依赖的生命周期管理。
5. 组件扫描机制
Spring通过组件扫描机制来自动检测并注册组件。在Spring配置文件中,可以使用<context:component-scan>
标签来指定扫描的包路径。
技术实现细节:
- Spring容器会扫描指定包路径下的类,查找带有特定注解(如
@Component
)的类。 - 扫描到的类会被注册为Bean,并在Spring容器中进行管理。
6. Bean作用域
Bean作用域定义了Spring容器中Bean的生命周期和可重用性。常见的Bean作用域包括:
- Singleton:默认作用域,表示每个Spring容器中只有一个实例。
- Prototype:表示每次请求都创建一个新的实例。
- Request:表示每个HTTP请求创建一个新的实例。
- Session:表示每个HTTP会话创建一个新的实例。
技术实现细节:
- Bean作用域可以通过
@Scope
注解或Spring配置文件进行设置。 - Singleton作用域适用于单例模式,Prototype作用域适用于多例模式。
- Request和Session作用域适用于Web应用场景,分别对应HTTP请求和会话。
7. 条件化配置(@Conditional)
条件化配置允许在创建Bean时根据特定的条件进行判断。Spring提供了多种条件注解,如@ConditionalOnClass
、@ConditionalOnBean
等。
技术实现细节:
- 条件注解可以应用于Bean定义或配置类,根据条件判断是否创建Bean或执行配置。
- 条件注解可以根据类路径、Bean存在性、属性值等因素进行判断。
二、AOP技术体系
面向切面编程(AOP)是一种编程范式,它允许我们将横切关注点(如日志、安全、事务等)与业务逻辑分离。下面介绍AOP技术体系。
1. 代理模式实现
Spring AOP通过代理模式来实现AOP。代理模式分为两种实现方式:JDK动态代理和CGLIB代理。
技术实现细节:
- JDK动态代理适用于实现了至少一个接口的类,通过
java.lang.reflect.Proxy
类创建代理。 - CGLIB代理适用于没有实现接口或者实现多个接口的类,通过
org.springframework.cglib.proxy
包中的类创建代理。 - 代理模式允许在目标对象周围添加额外的逻辑,如前置通知、后置通知、环绕通知等。
2. 切点表达式语法
切点表达式用于定义AOP中的切点。Spring提供了多种切点表达式,如execution
、within
、this
等。
技术实现细节:
execution
表达式用于匹配方法执行,可以指定方法名、返回类型、参数类型等。within
表达式用于匹配指定包或类的方法。this
表达式用于匹配代理对象所属的类。
3. 通知类型
通知是AOP中的关键概念,它定义了切点执行时触发的操作。Spring提供了以下通知类型:
- 前置通知(Before):在目标方法执行之前执行。
- 后置通知(After):在目标方法执行之后执行。
- 环绕通知(Around):在目标方法执行之前和之后执行。
- 异常通知(AfterThrowing):在目标方法抛出异常时执行。
- 最终通知(AfterReturning):在目标方法正常执行完成后执行。
技术实现细节:
- 通知可以通过
@Before
、@After
、@Around
、@AfterThrowing
、@AfterReturning
等注解进行定义。 - 通知方法可以访问目标方法的参数、返回值、异常等信息。
4. AOP应用场景
AOP在以下场景中非常有用:
- 日志管理:记录方法执行日志、异常日志等。
- 性能监控:监控方法执行时间、资源使用情况等。
- 安全控制:实现方法访问控制、权限控制等。
三、数据持久化
Spring框架提供了数据持久化解决方案,包括JDBC模板、事务管理、ORM集成等。
1. JDBC模板
JDBC模板是Spring提供的一种简化JDBC操作的工具类。它通过封装JDBC操作,使得代码更加简洁易读。
技术实现细节:
- JDBC模板提供了多种方法,如
queryForList
、update
等,用于执行SQL查询和更新操作。 - JDBC模板自动处理数据库连接、事务管理等,简化了JDBC操作。
- JDBC模板可以与Spring的事务管理功能集成,实现声明式事务管理。
2. 事务管理
Spring提供了声明式事务管理,允许我们通过注解或配置文件来管理事务。声明式事务管理简化了代码,降低了事务管理的复杂性。
技术实现细节:
- Spring事务管理器负责管理事务的提交和回滚。
- 通过
@Transactional
注解,可以在方法级别或类级别声明事务。 - Spring事务管理器支持多种事务传播行为和隔离级别。
3. ORM集成
Spring框架支持多种ORM框架,如Hibernate、MyBatis等。下面以Hibernate为例,介绍Spring与Hibernate的集成。
技术实现细节:
- Spring通过
LocalSessionFactoryBean
和SessionFactory
来管理Hibernate会话。 - Spring提供了
HibernateTemplate
,简化了Hibernate的操作。 - Spring可以与Spring Data JPA集成,实现基于JPA规范的ORM操作。
4. 会话管理
Spring通过SessionFacotry
和SessionFactoryBean
来管理Hibernate会话。
技术实现细节:
SessionFacotry
负责创建和管理SessionFactory
。SessionFactory
负责创建和管理Session
。Session
负责执行数据库操作。
5. JPA规范实现
Spring Data JPA是Spring框架提供的一种基于JPA规范的ORM解决方案。它允许我们通过简单的接口来定义CRUD操作。
技术实现细节:
- Spring Data JPA通过接口继承的方式实现CRUD操作。
- Spring Data JPA提供了多种方法,如
save
、find
、delete
等,用于执行CRUD操作。 - Spring Data JPA支持自定义方法,方便实现复杂的查询。
6. 多数据源配置
Spring支持多数据源配置,允许我们在同一个Spring容器中管理多个数据源。
技术实现细节:
- Spring通过
AbstractRoutingDataSource
实现多数据源路由。 - 可以通过配置文件或代码设置不同数据源的连接信息。
- 可以根据不同的业务场景,选择不同的数据源。
四、Web开发体系
Spring框架提供了强大的Web开发体系,包括MVC架构、RESTful支持、异常处理等。
1. MVC架构
Spring MVC是一个基于MVC模式的Web框架,它将Web应用程序分为控制器(Controller)、模型(Model)和视图(View)三个部分。
技术实现细节:
- 控制器负责接收HTTP请求,并返回相应的响应。
- 模型负责封装业务逻辑和数据。
- 视图负责展示数据。
2. 视图解析
Spring MVC提供了多种视图解析器,如Thymeleaf、JSP等。
技术实现细节:
- 视图解析器负责将视图名称转换为视图对象。
- 可以通过配置文件或代码设置视图解析器。
3. 数据绑定
Spring MVC允许我们将请求参数绑定到控制器方法的参数中。
技术实现细节:
- Spring MVC使用
@RequestParam
、@PathVariable
等注解将请求参数绑定到控制器方法的参数中。 - 可以使用自定义的类型转换器将请求参数转换为特定的数据类型。
4. RESTful支持
Spring MVC支持RESTful风格的URL,允许我们通过HTTP方法来操作资源。
技术实现细节:
- Spring MVC使用
@RestController
、@RequestMapping
等注解来定义RESTful控制器。 - 可以使用
@GetMapping
、@PostMapping
等注解来定义不同的HTTP方法。
5. 异常处理机制
Spring MVC提供了异常处理机制,允许我们自定义异常处理逻辑。
技术实现细节:
- Spring MVC使用
@ControllerAdvice
、@ExceptionHandler
等注解来定义异常处理器。 - 可以使用自定义的异常处理器来处理不同的异常。
6. 文件上传下载
Spring MVC提供了文件上传下载的功能,允许我们上传和下载文件。
技术实现细节:
- Spring MVC使用
MultipartFile
接口来处理文件上传。 - 可以使用
HttpServletResponse
来处理文件下载。
五、安全框架
Spring框架提供了安全框架,允许我们实现认证、授权、CSRF防护等功能。
1. 认证流程
认证流程包括以下步骤:
- 用户登录:用户输入用户名和密码。
- 验证用户:服务器验证用户名和密码是否正确。
- 登录成功:用户登录成功,系统分配一个会话。
- 登录失败:用户登录失败,返回错误信息。
技术实现细节:
- Spring Security框架提供了认证和授权功能。
- 可以使用表单认证、基于令牌的认证、OAuth2认证等不同的认证方式。
- 可以通过配置文件或代码设置认证成功和失败的处理逻辑。
2. 授权模型
授权模型包括以下步骤:
- 权限验证:验证用户是否有权限访问资源。
- 权限判断:根据用户的权限判断是否允许访问资源。
技术实现细节:
- Spring Security框架提供了基于角色的权限控制功能。
- 可以使用
@PreAuthorize
、@PostAuthorize
等注解来控制方法访问权限。 - 可以使用自定义的权限验证器来实现更复杂的权限控制。
3. CSRF防护
CSRF(跨站请求伪造)是一种攻击方式,Spring框架提供了CSRF防护机制,防止CSRF攻击。
技术实现细节:
- Spring Security框架通过添加CSRF令牌来防止CSRF攻击。
- 可以通过配置文件或代码设置CSRF令牌的生成和验证逻辑。
4. OAuth2集成方法
OAuth2是一种授权框架,Spring框架提供了OAuth2客户端和资源服务器的实现。
技术实现细节:
- Spring Security OAuth2框架提供了OAuth2认证和授权功能。
- 可以使用Spring Security OAuth2框架实现OAuth2认证服务器和资源服务器。
- 可以通过配置文件或代码设置OAuth2认证和授权的配置。
5. 方法级安全
Spring框架允许我们在方法级别上定义安全策略。
技术实现细节:
- 可以使用
@PreAuthorize
、@PostAuthorize
等注解来控制方法访问权限。 - 可以使用自定义的权限验证器来实现更复杂的方法级安全策略。
六、高级特性
Spring框架提供了许多高级特性,如事件发布/监听机制、SpEL表达式、响应式编程等。
1. 事件发布/监听机制
Spring框架允许我们定义事件和监听器,实现事件发布/监听机制。
技术实现细节:
- 可以使用
ApplicationEvent
和ApplicationListener
来定义事件和监听器。 - 可以使用
ApplicationEventMulticaster
来发布事件。 - 可以使用自定义的事件和监听器来实现更复杂的事件处理逻辑。
2. SpEL表达式
SpEL(Spring Expression Language)是一种表达式语言,用于在运行时计算值。
技术实现细节:
- SpEL表达式可以应用于各种场景,如属性值、方法参数等。
- 可以使用SpEL表达式进行复杂的逻辑计算,如条件判断、循环等。
3. 响应式编程(WebFlux)
响应式编程是Spring 5.0引入的一种编程范式,它允许我们以非阻塞的方式处理事件。
技术实现细节:
- Spring WebFlux框架支持响应式编程,允许我们使用异步编程模型。
- 可以使用
Mono
、Flux
等响应式类型来处理事件。 - 可以使用WebFlux框架实现非阻塞的Web应用程序。
4. 测试框架集成
Spring框架支持多种测试框架,如JUnit、TestNG等。
技术实现细节:
- Spring提供了
@RunWith
、@SpringBootTest
等注解来简化测试。 - 可以使用Spring Test框架进行集成测试和单元测试。
- 可以使用Mockito等框架模拟依赖对象。
5. 缓存抽象
Spring框架提供了缓存抽象,允许我们实现缓存机制。
技术实现细节:
- Spring Cache框架提供了缓存抽象,允许我们使用不同的缓存实现。
- 可以使用
@Cacheable
、@CachePut
、@CacheEvict
等注解来控制缓存操作。 - 可以使用不同的缓存提供者,如Redis、Caffeine等。
七、Spring Boot生态
Spring Boot是Spring框架的一个模块,它简化了Spring应用的创建和配置过程。
1. 自动配置原理
Spring Boot通过自动配置原理来自动配置Spring应用。它通过条件化配置、配置文件解析、类路径扫描等机制来实现自动配置。
技术实现细节:
- Spring Boot使用条件化配置来决定是否启用某些功能。
- Spring Boot解析配置文件,并将配置信息注入到Spring容器中。
- Spring Boot通过类路径扫描来查找Bean定义,并自动注册到Spring容器中。
2. Starter机制
Spring Boot提供了Starter机制,允许我们通过简单的依赖关系来配置Spring应用。
技术实现细节:
- Spring Boot Starter是Spring Boot提供的依赖关系,它包含了所需的库和配置。
- 可以通过添加Starter依赖来启用特定的功能。
- 可以通过自定义Starter来扩展Spring Boot的功能。
3. Actuator监控
Spring Boot Actuator允许我们监控和管理Spring应用。
技术实现细节:
- Spring Boot Actuator提供了多种端点,如
/health
、/info
、/metrics
等。 - 可以使用Spring Boot Actuator来收集应用程序的性能数据。
- 可以使用Spring Boot Actuator来配置和管理应用程序的监控。
4. 配置文件体系
Spring Boot提供了多种配置文件,如application.properties、application.yml等。
技术实现细节:
- Spring Boot使用配置文件来存储应用程序的配置信息。
- 可以使用properties文件或YAML文件来配置应用程序。
- 可以使用配置文件来设置环境变量、属性值等。
通过以上补充说明,文章的专业性和技术深度得到了提升,为读者提供了更全面、更深入的技术理解。
博主分享
📥博主的人生感悟和目标
📙经过多年在CSDN创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续出版。
- 《Java项目实战—深入理解大型互联网企业通用技术》基础篇的购书链接:https://item.jd.com/14152451.html
- 《Java项目实战—深入理解大型互联网企业通用技术》基础篇繁体字的购书链接:http://product.dangdang.com/11821397208.html
- 《Java项目实战—深入理解大型互联网企业通用技术》进阶篇的购书链接:https://item.jd.com/14616418.html
- 《Java项目实战—深入理解大型互联网企业通用技术》架构篇待上架
- 《解密程序员的思维密码--沟通、演讲、思考的实践》购书链接:https://item.jd.com/15096040.html
面试备战资料
八股文备战
场景 | 描述 | 链接 |
---|---|---|
时间充裕(25万字) | Java知识点大全(高频面试题) | Java知识点大全 |
时间紧急(15万字) | Java高级开发高频面试题 | Java高级开发高频面试题 |
理论知识专题(图文并茂,字数过万)
技术栈 | 链接 |
---|---|
RocketMQ | RocketMQ详解 |
Kafka | Kafka详解 |
RabbitMQ | RabbitMQ详解 |
MongoDB | MongoDB详解 |
ElasticSearch | ElasticSearch详解 |
Zookeeper | Zookeeper详解 |
Redis | Redis详解 |
MySQL | MySQL详解 |
JVM | JVM详解 |
集群部署(图文并茂,字数过万)
技术栈 | 部署架构 | 链接 |
---|---|---|
MySQL | 使用Docker-Compose部署MySQL一主二从半同步复制高可用MHA集群 | Docker-Compose部署教程 |
Redis | 三主三从集群(三种方式部署/18个节点的Redis Cluster模式) | 三种部署方式教程 |
RocketMQ | DLedger高可用集群(9节点) | 部署指南 |
Nacos+Nginx | 集群+负载均衡(9节点) | Docker部署方案 |
Kubernetes | 容器编排安装 | 最全安装教程 |
开源项目分享
项目名称 | 链接地址 |
---|---|
高并发红包雨项目 | https://gitee.com/java_wxid/red-packet-rain |
微服务技术集成demo项目 | https://gitee.com/java_wxid/java_wxid |
管理经验
【公司管理与研发流程优化】针对研发流程、需求管理、沟通协作、文档建设、绩效考核等问题的综合解决方案:https://download.csdn.net/download/java_wxid/91148718
希望各位读者朋友能够多多支持!
现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!
- 💂 博客主页: Java程序员廖志伟
- 👉 开源项目:Java程序员廖志伟
- 🌥 哔哩哔哩:Java程序员廖志伟
- 🎏 个人社区:Java程序员廖志伟
- 🔖 个人微信号:
SeniorRD
🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~