当前位置: 首页 > 面试题库 >

在Spring Boot中禁用所有与数据库相关的自动配置

岳刚洁
2023-03-14
问题内容

我正在使用Spring
Boot开发两个应用程序,一个用作服务器,另一个是客户端应用程序。但是,它们都是同一个应用程序,根据活动配置文件的功能有所不同。我正在使用Spring
Boot的自动配置功能来配置我的应用程序。

我想在客户端应用程序上禁用所有与数据库相关的自动配置,因为它不需要数据库连接。应用程序不应尝试与数据库建立连接,也不应尝试使用任何Spring
Data或Hibernate功能。启用或禁用数据库自​​动配置应该是有条件的,并且应基于应用程序的活动配置文件。

我可以通过为各自的配置文件创建两个不同的application.properties文件来实现此目的吗?

我尝试将其添加到属性文件中,

spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration\
  org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration\
org.springframework.boot.autoconfigure.jdbc.DataSourceTransactionManagerAutoConfiguration\
  org.springframework.boot.autoconfigure.data.web.SpringDataWebAutoConfiguration

但是,该应用程序仍然尝试在启动时连接到数据库。这些排除条件足以满足我的要求吗?


问题答案:

我做类似事情的方式是:

@Configuration
@EnableAutoConfiguration(exclude = {DataSourceAutoConfiguration.class, DataSourceTransactionManagerAutoConfiguration.class, HibernateJpaAutoConfiguration.class})
@Profile ("client_app_profile_name")
public class ClientAppConfiguration {
    //it can be left blank
}

为服务器应用程序编写类似的内容(不排除)。

最后一步是从主spring引导类禁用Auto Configuration:

@SpringBootApplication
public class SomeApplication extends SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(SomeApplication.class);
    }

    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
        return application.sources(SomeApplication.class);
    }
}

更改@SpringBootApplication为:

@Configuration 
@ComponentScan

这应该做的工作。现在,我在示例中排除的依赖项可能不完整。它们对我来说足够了,但是我不确定是否完全禁用数据库相关的库。检查以下列表以确保:

http://docs.spring.io/spring-boot/docs/current-
SNAPSHOT/reference/html" target="_blank">htmlsingle/#auto-configuration-
classes

希望能有所帮助



 类似资料:
  • 我正在使用spring boot开发两个应用程序,一个充当服务器端,另一个是客户端应用程序。然而,这两个应用程序是相同的功能不同的基于活动配置文件。我正在使用spring boot的自动配置功能来配置我的应用程序。 我想禁用所有数据库相关的客户端应用程序自动配置,因为它将不需要数据库连接。应用程序不应尝试与数据库建立连接,也不应尝试使用任何spring数据或Hibernate特性。数据库自动配置的

  • 我有一个简单的SpringBoot应用程序,我想使用AutoConfiguration来配置Tomcat jdbc池数据源。 我正在使用这些Spring依赖项: 以下是我的 application.yml 文件中的数据源属性: 我确定正在加载属性,因为应用程序正在获取其他值。 我在配置文件中将 bean 定义为: 我将数据源注入到我的DAO中,如下所示: 如果我在getDataSource()方法

  • 当应用程序启动时,我正在尝试创建mysql数据库。我尝试了波纹管配置,但无法实现,如果有人对此有想法,请告诉我,

  • 我有一个spring-boot项目,该项目创建了一个H2内存数据库,其中包含由带有@Entity注释的类自动生成的表。我现在已经创建了另一个项目来连接到同一个数据库,但是每当我运行新的spring项目时,我认为创建了一个新的数据库来覆盖另一个数据库。 更新 尝试przemek hertel给出的答案,我得到以下错误:

  • 4.1 根据条件的自动配置 @conditional是基于条件的自动配置,一般配合Condition接口一起使用,只有接口实现类返回true,才装配,否则不装配. 用实现了Condition接口的类传入@Conditional中 @Conditional可以标记在配置类的方法中,也可以标记在配置类上.标记的位置不同,作用域不同. @Conditional可以传入多个实现了condition接口的类

  • 问题内容: 我想知道是否有一种方法可以将我的id列(自动递增)设置为使用mysql表中的前导零始终具有5位数字。因此,第一个值将是00001,然后是00002,依此类推,直到99999,而不是1,2,3,直到99999。 问题答案: 您的ID列是一个数字值,因此它将始终具有相同的值。如果要以某种方式格式化整数,则必须将其格式化为SELECT的一部分。查看LPAD函数。 LPAD前导零