怎么理解 Spring Boot 中的约定大于配置?

 作者简介:大家好,我是码炫码哥,前中兴通讯、美团架构师,现任某互联网公司CTO,兼职码炫课堂主讲源码系列专题


代表作:《jdk源码&多线程&高并发》,《深入tomcat源码解析》,《深入netty源码解析》,《深入dubbo源码解析》,《深入springboot源码解析》,《深入spring源码解析》,《深入redis源码解析》等


联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬。码炫课堂的个人空间-码炫码哥个人主页-面试,源码等

回答

“约定大于配置”是 Spring Boot 的核心理念之一,目的是简化开发过程,减少我们在配置上的繁琐工作。具体来说,就是 Spring Boot 通过一系列的默认设置和约定,减少了我们需要显式配置的内容,从而让我们专注于业务逻辑,而不必过多关注框架的配置细节。

它主要从以下几个方面体现:

  1. 默认配置:Spring Boot 提供了大量的默认配置,一些常见的框架,如 MySQL、redis、JPA 等等,我们可以在不做任何额外配置的情况下就可以自动工作。
  2. 自动化配置:Spring Boot 可以通过 @EnableAutoConfiguration 注解和大量的自动配置类(@Configuration)来自动根据项目的类路径和环境来选择合适的配置。例如,当 Spring Boot 检测到我们使用了 H2 数据库,它会自动配置一个内存数据库的连接。
  3. 外部化配置:通过 application.properties 或 application.yml 文件,我们可以非常灵活地修改应用的行为,Spring Boot 会根据这些配置文件来覆盖默认设置,但大多数情况下,默认配置就已经足够满足开发需求。

其实一句话就可以解释:约定大于配置就是减少配置!!!

详解

约定大于配置解释

维基百科解释如下:

约定优于配置(convention over configuration),也称作按约定编程,是一种软件设计范式,旨在减少软件开发人员需做出决定的数量,活得简单的好处,而又不失灵活性。

本质上是说,开发人员仅需要规定应用中不符约定的部分,例如,如果模型中有个名为 Sale 的类,那么数据库中对应的表就会默认命名为 sales。只有偏离这一约定时,例如将该表命名为“products_sold”,才需写有关这个名字的配置。

如果您所用工具的约定与你的期望相符,便可省去配置;反之,你可以配置来达到你所期待的方式。

设计不好的框架通常需要多个配置文件,每一个都有许多设置。这些配置文件为每一个项目提供像是URL,或是将类映射到数据库表的各种信息。大量包含太多参数的配置文件通常是过度复杂的应用设计(代码坏味道)。 例如,在知名的Java对象关系映射框架Hibernate的早期版本中,将类及其属性映射到数据库上需要是在XML文件中的描述,其中大部分信息都应能够按照约定得到,如将类映射到同名的数据库表,将属性分别映射到表上的字段。后续的版本抛弃了XML配置文件,而是使用这些恰当的约定,对于不符合这些约定的情形,可以使用Java 标注来说明。

码哥理解:

“约定大于配置”是指框架在大多数情况下提供了符合常规应用需求的默认设置,我们只需要遵循这些约定,而不必为每个细节都编写配置。这就让我们不必关注每个小配置项的选择,减少了出错的概率,同时也提高了开发效率。Spring Boot 倡导的这种约定和默认配置方式,极大地降低了配置的复杂度。

Spring Boot 中的约定大于配置

默认配置

Spring Boot 为常用的框架都提供了大量的默认配置。

Spring Boot 在启动时会自动根据当前环境和类路径中的依赖来决定合适的默认配置。例如,Spring Boot 会根据类路径中是否存在某个组件来决定是否启用相关的自动配置。当我们使用 Spring Boot 开发一个 Web 应用时,Spring Boot 会自动配置嵌入式的 Tomcat 服务器、Spring MVC、默认的视图解析器等,而不需要我们手动配置这些内容。Spring Boot 中的 spring-boot-starter-web 依赖就包含了 Web 开发所需的全部配置。

自动配置机制

Spring Boot 通过 @EnableAutoConfiguration 来实现自动配置,这个注解会引导 Spring Boot 扫描类路径下的条件并启用对应的自动配置。

Spring Boot 中的自动配置机制可以根据项目中包含的依赖和当前的环境来决定是否引入某个组件,所以,如果我们使用了特定的数据库、缓存、消息队列或者 Web 框架时,Spring Boot 会自动配置合适的组件。例如,我们在 pom.xml 添加了 Spring Data JPA 依赖,Spring Boot 会自动为我们配置 JPA 的 EntityManagerFactory、数据源、事务管理等。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

外部化配置

尽管 Spring Boot 提供了许多默认配置,但是我们仍然可以通过配置文件,如 application.properties 或 application.yml 来覆盖这些默认值。外部化配置的优点在于,不同的环境可以有不同的配置,我们不必在代码中硬编码配置。

Spring Boot 的默认约定

Spring Boot 提供了很多默认的约定来简化配置。比如 Spring Boot 约定项目结构如下:

/src/main/java:目录用来存放 java 源文件
/src/main/resources:目录用来存放资源文件,如 application.yml 文件,MyBatis的*mapper.xml文件
/src/test/java:目录用来存放 java 测试文件
/src/test/resources:目录用来存放测试资源文件
/target:目录为项目的输出位置

再比如,Spring Boot 提供了大量的 starter 依赖,我们只需要引入对应的 starter,就能自动配置好相关的组件。如使用 spring-boot-starter-web 作为 Web 应用的依赖,Spring Boot 会自动为我们配置好 Spring MVC、嵌入式 Tomcat 等基础设施,避免了繁琐的手动配置。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值