我正在使用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前导零