学习认识Spring Boot Starter

简介: 在SpringBoot项目中,经常能够在pom文件中看到以spring-boot-starter-xx或xx-spring-boot-starter命名的一些依赖。例如:spring-boot-starter-web、spring-boot-starter-security、spring-boot-starter-data-jpa、mybatis-spring-boot-starter等等。

一、什么是 Spring Boot Starter?

在SpringBoot项目中,经常能够在pom文件中看到以spring-boot-starter-xx或xx-spring-boot-starter命名的一些依赖。例如:spring-boot-starter-web、spring-boot-starter-security、spring-boot-starter-data-jpa、mybatis-spring-boot-starter等等。

Spring Boot Starter 是一组便捷的依赖描述符,它们封装了特定技术或功能的所有必要依赖项和配置,使开发者能够快速将这些功能集成到 Spring Boot 项目中。每个 Starter 都对应一个功能或技术栈,通过引入相应的 Starter,开发者无需手动配置和管理多个相关依赖项,就能轻松启用该功能。

二、Starter 与普通依赖的区别

Spring Boot Starter 和普通依赖(普通 Jar 包)的主要区别在于 Starter 是一组便捷的依赖集合和自动配置的封装,而普通依赖只是单一的功能库或框架。以下是一些对比:

1. 依赖管理

Spring Boot Starter:

通过一个依赖引入一组相关依赖。例如引入 spring-boot-starter-web 会同时引入 Spring MVC、Tomcat 和 Jackson 等依赖。

简化了项目的依赖管理,减少了配置的复杂性。

普通依赖:

需要手动逐个添加相关的依赖。例如,如果需要 Spring MVC 和 Jackson,需要分别添加这两个依赖。依赖管理较为繁琐,需要开发者对各个依赖及其版本有较好的掌握。

2. 自动配置

Spring Boot Starter:

通常配合 Spring Boot 的自动配置机制使用,提供默认的自动配置,使项目开箱即用。

通过 spring.factories 文件自动注册相关的自动配置类,无需手动配置 Bean。

新版本中,文件名为org.springframework.boot.autoconfigure.AutoConfiguration.imports

普通依赖:

需要手动进行相关配置。使用某个库后,需要在配置文件或代码中手动配置对应的 Bean。

缺乏统一的自动配置机制,配置过程可能较为繁琐。

3. 最佳实践

Spring Boot Starter:

封装了社区和 Spring 团队的最佳实践,提供合理的默认配置,适合大多数应用场景。

减少了初学者的学习曲线,开发者无需了解底层实现细节即可快速使用。

普通依赖:

配置依赖时需要开发者自行决定各个依赖的配置方式,可能会导致不一致或不合理的配置。

适合需要细粒度控制和定制化配置的场景。

4. 模块化

Spring Boot Starter:

提供了功能模块化的方式,通过不同的 Starter 可以快速集成不同的功能模块。

例如,使用 spring-boot-starter-data-jpa 可以快速集成 JPA 持久化,使用 spring-boot-starter-security 可以快速集成安全功能。

普通依赖:

需要手动组合和配置不同的依赖,缺乏模块化的便捷性。

不同的依赖之间可能存在兼容性问题,需要开发者自行解决。

三、为什么需要自定义 Starter?

在 Spring Boot 项目中,自定义 Starter 可以极大地简化和标准化特定功能的集成和配置。以下是一些需要使用自定义 Starter 的场景:

1. 重复使用的通用功能模块

当你有多个项目需要使用相同的功能模块时,可以创建一个自定义 Starter,将这些功能模块封装起来。这样可以减少代码重复,提高代码复用性。

示例:统一的日志处理模块、统一的异常处理模块等。

2. 复杂的第三方库集成

当集成第三方库时,如果需要复杂的配置和初始化,可以通过自定义 Starter 简化集成过程,提供更友好的使用方式。

示例:集成 Kafka、Redis、Elasticsearch 等中间件。

3. 公司内部的标准化开发框架

在企业内部,可以将一些标准化的开发规范和基础设施封装成自定义 Starter,使得团队内的所有项目都能遵循相同的规范和使用相同的基础设施。

示例:公司内部的监控系统、认证授权模块、消息队列封装等。

4. 统一配置和管理

当需要统一管理和配置某些功能时,可以通过自定义 Starter 进行集中管理,提供默认配置,并允许项目根据需要进行覆盖配置。

示例:统一的数据库连接池配置、安全配置等。

5. 封装复杂的初始化逻辑

有些功能的初始化过程非常复杂,如果每个项目都需要重复这部分初始化逻辑,可以通过自定义 Starter 封装这部分逻辑,简化项目的初始化过程。

示例:复杂的缓存管理、事务管理等。

6. 提供公共的 Bean 和配置

当需要在多个项目中提供相同的 Bean 和配置时,可以通过自定义 Starter 提供这些公共的 Bean 和配置,避免每个项目都重复定义。

示例:统一的服务发现客户端、统一的负载均衡策略等。

相关文章
|
3天前
|
XML Java 数据格式
Spring5系列学习文章分享---第一篇(概述+特点+IOC原理+IOC并操作之bean的XML管理操作)
Spring5系列学习文章分享---第一篇(概述+特点+IOC原理+IOC并操作之bean的XML管理操作)
9 1
|
3天前
|
XML druid Java
Spring5系列学习文章分享---第二篇(IOC的bean管理factory+Bean作用域与生命周期+自动装配+基于注解管理+外部属性管理之druid)
Spring5系列学习文章分享---第二篇(IOC的bean管理factory+Bean作用域与生命周期+自动装配+基于注解管理+外部属性管理之druid)
6 0
|
2天前
|
Java Maven 开发者
使用Spring Boot创建自定义Starter
使用Spring Boot创建自定义Starter
|
3天前
|
XML 安全 Java
Spring 基础知识学习
Spring 基础知识学习
|
3天前
|
Java Spring 容器
Spring5系列学习文章分享---第六篇(框架新功能系列+整合日志+ @Nullable注解 + JUnit5整合)
Spring5系列学习文章分享---第六篇(框架新功能系列+整合日志+ @Nullable注解 + JUnit5整合)
5 0
|
3天前
|
XML Java 数据库
Spring5系列学习文章分享---第五篇(事务概念+特性+案例+注解声明式事务管理+参数详解 )
Spring5系列学习文章分享---第五篇(事务概念+特性+案例+注解声明式事务管理+参数详解 )
6 0
|
3天前
|
SQL Java 数据库连接
Spring5系列学习文章分享---第四篇(JdbcTemplate+概念配置+增删改查数据+批量操作 )
Spring5系列学习文章分享---第四篇(JdbcTemplate+概念配置+增删改查数据+批量操作 )
6 0
|
3天前
|
XML Java 数据格式
Spring5系列学习文章分享---第三篇(AOP概念+原理+动态代理+术语+Aspect+操作案例(注解与配置方式))
Spring5系列学习文章分享---第三篇(AOP概念+原理+动态代理+术语+Aspect+操作案例(注解与配置方式))
7 0
|
3天前
|
安全 网络协议 Java
技术好文:SpringBoot学习(五)RSocket和Security
技术好文:SpringBoot学习(五)RSocket和Security
|
Java API Spring
Spring学习路径
Spring作为一个优秀的开源企业级框架有着一下特点 开源框架 简化企业级应用开发的流程 Spring是一个JavaSE/EE的一站式框架 优点在于 方便解耦 AOP的编程支持 声明式事务的支持 可以引入jUnit4,方便程序测试 对优秀开源框架的支持,方便集成 降低JavaEE API的使用难度.
2494 0