spring-boot-1.5.1-disable-auto-configuration

本文介绍了为何要禁用Spring Boot 1.5.1的自动配置,因为自动扫描会降低启动速度。通过创建maven工程,并展示pom.xml、项目目录结构以及各个层的配置,展示了禁用自动配置的实践案例。项目支持MySQL和Oracle数据库,启动后可通过特定URL进行访问和操作。禁用自动配置后,项目启动时间缩短,提高了效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

spring-boot-1.5.1-disable-auto-configuration

为什么要禁用自动配置

如果启用了自动配置spring-boot启动前会进行自动扫描,非常消耗时间,拖慢了启动速度

禁用自动配置案例

创建maven工程spring-boot-1.5.1-disable-auto-configuration

https://github.com/litongjava/spring-boot-1.5.1-disable-auto-configuration

pom.xml如下

<parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-parent</artifactId>
  <version>1.5.1.RELEASE</version>
</parent>
<properties>
  <!-- 文件拷贝时的编码 -->
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  <!-- 编译时的编码 -->
  <maven.compiler.encoding>UTF-8</maven.compiler.encoding>
  <!-- 定义java版本,只有继承spring-boot-starter-parent时才有效 -->
  <java.version>1.8</java.version>
</properties>
<dependencies>
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
  </dependency>
  <!-- spring-boot start -->
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
  </dependency>
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
  </dependency>

  <dependency>
    <groupId>org.apache.tomcat.embed</groupId>
    <artifactId>tomcat-embed-jasper</artifactId>
  </dependency>

  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
  </dependency>
  <!-- springboot starter data jpa -->
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
  </dependency>
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-security</artifactId>
  </dependency>

  <!-- mysql-connector -->
  <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
  </dependency>

  <!-- druid -->
  <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.5</version>
  </dependency>

  <dependency>
    <groupId>commons-httpclient</groupId>
    <artifactId>commons-httpclient</artifactId>
    <version>3.1</version>
  </dependency>

  <!--lombok start -->
  <dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <scope>provided</scope>
  </dependency>
  <!--lombok end -->

  <!--fastjson start -->
  <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.38</version>
  </dependency>
</dependencies>

项目目录结构

web:spring-boot-starter-web

security:>spring-boot-starter-security

data:spring-boot-starter-data-jpa

启动类内容如下

package com.alit.study.springboot;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.AutoConfigurationExcludeFilter;
import org.springframework.boot.autoconfigure.aop.AopAutoConfiguration;
import org.springframework.boot.autoconfigure.context.ConfigurationPropertiesAutoConfiguration;
import org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoConfiguration;
import org.springframework.boot.autoconfigure.dao.PersistenceExceptionTranslationAutoConfiguration;
import org.springframework.boot.autoconfigure.data.web.SpringDataWebAutoConfiguration;
import org.springframework.boot.autoconfigure.domain.EntityScan;
import org.springframework.boot.autoconfigure.info.ProjectInfoAutoConfiguration;
import org.springframework.boot.autoconfigure.jackson.JacksonAutoConfiguration;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.autoconfigure.jdbc.DataSourceTransactionManagerAutoConfiguration;
import org.springframework.boot.autoconfigure.jdbc.JdbcTemplateAutoConfiguration;
import org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration;
import org.springframework.boot.autoconfigure.security.SecurityAutoConfiguration;
import org.springframework.boot.autoconfigure.security.SecurityFilterAutoConfiguration;
import org.springframework.boot.autoconfigure.transaction.TransactionAutoConfiguration;
import org.springframework.boot.autoconfigure.transaction.jta.JtaAutoConfiguration;
import org.springframework.boot.autoconfigure.validation.ValidationAutoConfiguration;
import org.springframework.boot.autoconfigure.web.DispatcherServletAutoConfiguration;
import org.springframework.boot.autoconfigure.web.EmbeddedServletContainerAutoConfiguration;
import org.springframework.boot.autoconfigure.web.ErrorMvcAutoConfiguration;
import org.springframework.boot.autoconfigure.web.HttpEncodingAutoConfiguration;
import org.springframework.boot.autoconfigure.web.HttpMessageConvertersAutoConfiguration;
import org.springframework.boot.autoconfigure.web.MultipartAutoConfiguration;
import org.springframework.boot.autoconfigure.web.ServerPropertiesAutoConfiguration;
import org.springframework.boot.autoco
### 解决 Maven 项目中找不到 `com.spring4all:spring-boot-starter-freemarker:1.5.1.RELEASE` 依赖项的方法 当遇到无法找到特定版本的依赖项时,可以采取多种方法来解决问题。 #### 检查仓库配置 确保项目的 `pom.xml` 中包含了正确的仓库地址。有时第三方库可能不在中央Maven仓库中,而是位于其他公共或私有仓库里。对于 `spring-boot-starter-freemarker` 这样的组件,通常会存在于阿里云镜像或其他开源平台提供的额外仓库中[^1]。 ```xml <repositories> <repository> <id>aliyun</id> <url>https://maven.aliyun.com/repository/public/</url> </repository> </repositories> ``` #### 更新本地缓存并强制下载最新元数据 有时候由于网络原因或者本地缓存过期,可能会导致某些资源未能成功获取到最新的版本信息。可以通过命令行工具执行如下操作: ```bash mvn clean install -U ``` 此命令中的 `-U` 参数用于更新快照和发布版依赖。 #### 验证依赖声明准确性 确认所使用的坐标是否正确无误。根据官方文档或者其他可靠来源核实 groupId, artifactId 和 version 是否匹配目标构件的实际定义。如果确实存在该版本,则应能正常解析;反之则需考虑升级至更高版本或是寻找替代方案[^2]。 #### 使用较新版本的 Spring Boot Starter Parent 考虑到不同版本间的兼容性和维护状态差异较大,在条件允许的情况下建议尝试切换成更稳定的 parent 版本号,比如这里提到的是 `2.3.12.RELEASE` ,而实际应用中或许已经有更新的选择可用。 ```xml <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.0</version><!-- 或者选择适合生产环境稳定性的版本 --> </parent> ``` 通过上述措施往往能够有效处理大多数因缺少合适依赖而导致编译失败的情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值