📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)、《解密程序员的思维密码——沟通、演讲、思考的实践》作者、清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。
📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、SpringMVC、SpringCloud、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RocketMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。
📙不定期分享高并发、高可用、高性能、微服务、分布式、海量数据、性能调优、云原生、项目管理、产品思维、技术选型、架构设计、求职面试、副业思维、个人成长等内容。
💡在这个美好的时刻,笔者不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。
在Spring框架中,核心容器是其最基础的部分,它负责管理应用程序中的对象,即Bean。Spring容器通过IoC(控制反转)和DI(依赖注入)技术,实现了对Bean的创建、配置和管理。
IoC与DI
IoC是一种设计模式,它将对象的创建和依赖关系的配置从代码中分离出来,交由外部容器管理。在Spring中,IoC容器负责实例化Bean,并设置其依赖关系。这种模式使得对象之间的耦合度降低,提高了代码的可维护性和可测试性。
DI是IoC的一种实现方式,它通过注入的方式将依赖关系传递给对象。在Spring中,DI可以通过XML配置、注解或Java配置来实现。
Bean生命周期管理
Spring容器负责管理Bean的生命周期,包括创建、初始化、使用和销毁。Spring提供了多种初始化和销毁方法,如init-method
和destroy-method
,以及@PostConstruct
和@PreDestroy
注解。
Bean作用域
Spring支持多种Bean作用域,包括单例(Singleton)、原型(Prototype)、请求(Request)和会话(Session)等。单例作用域表示每个Spring容器中只有一个Bean实例,而原型作用域表示每次请求都会创建一个新的Bean实例。
BeanFactory与ApplicationContext
BeanFactory是Spring框架中最早期的容器,它提供了基本的Bean管理功能。ApplicationContext是BeanFactory的子接口,它提供了更丰富的功能,如国际化支持、事件传播等。
注解驱动开发
Spring提供了丰富的注解,如@Component
、@Service
、@Repository
、@Autowired
等,用于简化Bean的创建和配置。
Java配置
Spring允许使用Java代码来配置Bean,通过@Configuration
注解标记配置类,并使用@Bean
注解定义Bean。
XML配置驱动
Spring也支持使用XML文件来配置Bean,通过<bean>
标签定义Bean。
SpEL(Spring表达式语言)
SpEL是Spring提供的一种表达式语言,它可以用于在运行时动态地访问和操作对象属性、方法、集合等。
Spring AOP
Spring AOP是Spring框架提供的一种面向切面编程(AOP)的实现。AOP允许将横切关注点(如日志记录、事务管理等)与业务逻辑分离,从而提高代码的可维护性和可测试性。
切面(Aspect)
切面是包含横切关注点的类,它定义了通知(Advice)和切点(Pointcut)。
连接点(Join Point)
连接点是程序执行过程中的特定点,如方法执行、字段访问等。
通知(Advice)
通知是切面中定义的操作,如@Before
、@After
、@Around
、@AfterThrowing
、@AfterReturning
等。
切点(Pointcut)
切点是匹配连接点的表达式,用于确定哪些连接点应该被通知执行。
引入(Introduction)
引入允许在运行时动态地添加新的方法和属性到目标对象。
织入(Weaving)
织入是将切面应用到目标对象的过程。
@AspectJ注解支持
Spring支持使用@AspectJ注解来定义切面。
Spring数据访问与集成
Spring提供了丰富的数据访问和集成功能,包括JDBC抽象、事务管理、ORM集成和Spring Data等。
JDBC抽象(JdbcTemplate)
JdbcTemplate是Spring提供的一种JDBC抽象层,它简化了JDBC编程。
事务管理
Spring提供了声明式事务和编程式事务两种方式来管理事务。
事务传播机制
事务传播机制定义了事务边界,如PROPAGATION_REQUIRED
、PROPAGATION_REQUIRES_NEW
等。
事务隔离级别
事务隔离级别定义了事务并发执行时的隔离程度,如READ_COMMITTED
、REPEATABLE_READ
等。
DAO支持
Spring提供了DAO(数据访问对象)支持,简化了数据访问层的开发。
ORM集成
Spring支持多种ORM框架,如Hibernate、JPA和MyBatis。
Spring Data
Spring Data提供了一种声明式的方式来访问数据源,支持JPA、MongoDB、Redis等。
Spring Web与MVC
Spring Web是Spring框架的一部分,它提供了Web应用程序开发的支持。Spring MVC是Spring Web的MVC(模型-视图-控制器)实现。
DispatcherServlet
DispatcherServlet是Spring MVC的前端控制器,它负责接收请求并调用相应的处理器。
控制器(@Controller, @RestController)
控制器负责处理请求并返回响应。
请求映射(@RequestMapping, @GetMapping, @PostMapping)
请求映射用于将HTTP请求映射到控制器方法。
视图解析(ViewResolver)
视图解析器用于解析视图名称并返回相应的视图对象。
数据绑定(@RequestParam, @PathVariable, @RequestBody)
数据绑定用于将请求参数绑定到控制器方法参数。
返回处理(@ResponseBody, ResponseEntity)
返回处理用于返回JSON、XML等数据。
文件上传(MultipartFile)
文件上传用于处理文件上传请求。
拦截器(HandlerInterceptor)
拦截器用于在请求处理过程中拦截请求和响应。
异常处理(@ControllerAdvice, @ExceptionHandler)
异常处理用于处理控制器抛出的异常。
Spring WebFlux
Spring WebFlux是Spring框架的响应式Web框架,它支持异步和非阻塞编程。
Spring Boot核心特性
Spring Boot简化了Spring应用程序的开发,提供了自动配置、起步依赖、嵌入式容器、配置文件、Profile多环境配置、Actuator应用监控和Spring Boot CLI等特性。
自动配置(Auto-Configuration)
自动配置是Spring Boot的核心特性之一,它可以根据类路径下添加的jar依赖自动配置Bean。
起步依赖(Starter POMs)
起步依赖是Spring Boot提供的依赖管理方式,它简化了依赖的添加和版本管理。
嵌入式容器
Spring Boot支持多种嵌入式容器,如Tomcat、Jetty和Undertow。
配置文件
Spring Boot使用application.properties
或application.yml
文件来配置应用程序。
Profile多环境配置
Spring Boot支持多环境配置,可以根据不同的环境加载不同的配置文件。
Actuator(应用监控)
Actuator是Spring Boot提供的一种应用监控工具,它可以监控应用程序的健康状态、性能指标等。
Spring Boot CLI
Spring Boot CLI是Spring Boot提供的命令行工具,它可以快速启动和运行Spring Boot应用程序。
Spring Cloud微服务组件
Spring Cloud是一套微服务开发工具集,它提供了服务注册与发现、负载均衡、服务调用、熔断器、网关、配置中心、消息总线、链路追踪、分布式事务、安全与认证、监控与管理等微服务组件。
服务注册与发现
服务注册与发现是微服务架构的核心组件之一,它允许服务实例注册到注册中心,并发现其他服务实例。
负载均衡
负载均衡用于将请求分发到多个服务实例,以提高系统的可用性和性能。
服务调用
服务调用用于调用其他服务实例的方法。
熔断器
熔断器用于防止系统过载,当服务实例出现问题时,熔断器会阻止请求到达该服务实例。
网关
网关用于统一入口,对进入系统的请求进行路由和过滤。
配置中心
配置中心用于集中管理应用程序的配置信息。
消息总线
消息总线用于在微服务之间传递消息。
链路追踪
链路追踪用于追踪请求在微服务之间的传递路径。
分布式事务
分布式事务用于确保多个服务实例之间的操作要么全部成功,要么全部失败。
安全与认证
安全与认证用于保护微服务,防止未授权访问。
监控与管理
监控与管理用于监控微服务的健康状态和性能指标。
Spring Security安全
Spring Security是Spring框架提供的一种安全框架,它提供了身份认证、授权、表单登录与注销、OAuth2协议支持、JWT等安全功能。
身份认证(Authentication)
身份认证用于验证用户的身份。
授权(Authorization)
授权用于确定用户是否有权限执行特定的操作。
表单登录与注销
表单登录与注销用于处理用户的登录和注销操作。
OAuth2协议支持
OAuth2协议支持用于实现第三方登录。
JWT(JSON Web Token)
JWT是一种轻量级的安全令牌,用于在网络上安全地传输信息。
方法级安全(@PreAuthorize)
方法级安全用于在方法级别上实现安全控制。
CSRF防护
CSRF防护用于防止跨站请求伪造攻击。
Spring设计模式应用
Spring框架在设计时应用了多种设计模式,如工厂模式、单例模式、代理模式、模板方法、观察者模式、适配器模式等。
工厂模式(BeanFactory)
工厂模式用于创建对象实例,Spring容器通过BeanFactory实现工厂模式。
单例模式(Bean作用域)
单例模式确保每个Bean只有一个实例。
代理模式(AOP动态代理)
代理模式用于动态创建代理对象,Spring AOP通过动态代理实现代理模式。
模板方法(JdbcTemplate, RestTemplate)
模板方法用于定义算法的骨架,具体实现由子类完成。
观察者模式(ApplicationEvent)
观察者模式用于实现事件监听机制,Spring通过ApplicationEvent实现观察者模式。
适配器模式(HandlerAdapter)
适配器模式用于将接口转换成客户端期望的接口,Spring通过HandlerAdapter实现适配器模式。
其他关键模块
Spring框架还提供了其他关键模块,如Spring Messaging、Spring Integration、Spring Batch、Spring Session、Spring Cache等。
Spring Messaging(JMS集成)
Spring Messaging提供了对JMS(Java消息服务)的支持,允许应用程序使用JMS进行消息传递。
Spring Integration(企业集成模式)
Spring Integration提供了一种声明式的方式来实现企业集成模式,它支持多种消息传递机制,如JMS、RabbitMQ、Kafka等。
Spring Batch(批处理)
Spring Batch提供了一种声明式的方式来实现批处理任务,它支持多种批处理操作,如读取、处理、写入等。
Spring Session(分布式会话管理)
Spring Session提供了一种分布式会话管理机制,允许应用程序在多个服务器之间共享会话信息。
Spring Cache(缓存抽象:@Cacheable)
Spring Cache提供了一种缓存抽象,允许应用程序使用缓存来提高性能。
博主分享
📥博主的人生感悟和目标
📙经过多年在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
🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~