SpringBoot 五大实用小技巧
Spring Boot 执行初始化逻辑
背景
项目的某次更新,数据库中的某张表新增了一个字段,且与业务有关联,需要对新建的字段根据对应的业务进行赋值操作。
一种解决方案就是,更新前手动写 SQL 更新字段的值,但这样做的效率太低,而且每给不同环境更新一次,就需要手动执行一次,容易出错且效率低。
另一种方案则是在项目启动时进行初始化操作,完成字段对应值的更新,这种方案效率更高且不容易出错。
实现
Spring Boot 提供了多种方案用于项目启动后执行初始化的逻辑。
实现CommandLineRunner接口,重写run方法。
@Slf4j
@Component
public class InitListen implements CommandLineRunner {
@Override
public void run(String... args) {
// 初始化相关逻辑...
}
}
实现ApplicationRunner接口,重写run方法。
@Slf4j
@Component
public class InitListen implements ApplicationRunner {
@Override
public void run(ApplicationArguments args) {
// 初始化相关逻辑...
}
}
实现ApplicationListener接口
@Slf4j
@Configuration
public class StartClientListener implements ApplicationListener<ContextRefreshedEvent> {
@Override
public void onApplicationEvent(ContextRefreshedEvent arg0) {
// 初始化逻辑
}
}
针对于上述这个需求,如何实现仅更新一次字段的值?
可在数据库字典表中设置一个更新标识字段,每次执行初始化逻辑之前,校验判断下字典中的这个值,确认是否已经更新,如果已经更新,就不需要再执行更新操作了。
Spring Boot 动态控制数据源的加载
背景
期望通过在application.yml文件中,添加一个开关来控制是否加载数据库。
实现
启动类上添加注解 @SpringBootApplication(exclude = { DataSourceAutoConfiguration.class }),代表禁止 Spring Boot 自动注入数据源。
新建 DataSourceConfig配置类,用于初始化数据源。
在DataSourceConfig配置类上添加条件注解 @ConditionalOnProperty(name = “spring.datasource.enabled”, havingValue = “true”),代表只有当 spring.datasource.enabled 为 true时,加载数据库,其余情况不加载数据库。
仓库类 XxxRepository 的注入,需要使用注解 @Autowired(required = false)
Spring Boot 根据不同环境加载配置文件
背景
实际开发工作中,针对同一个项目,可能会存在开发环境、测试环境、正式环境等,不同环境的配置内容可能会不一致,如:数据库、Redis等等。期望在项目在启动时能够针对不同的环境来加载不同的配置文件。
实现
Spring 提供 Profiles 特性,通过启动时设置指令 -Dspring.profiles.active 指定加载的配置文件,同一个配置文件中不同的配置使用 — 来区分。
启动 jar 包时执行命令:
java -jar test.jar -Dspring.profiles.active=dev
-Dspring.profiles.active=dev代表激活 profiles 为 dev 的相关配置。
## 用---区分环境,不同环境获取不同配置
---
# 开发环境
spring:
profiles: dev
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
# 命名空间为默认,所以不需要写命名空间
config:
server-addr: ${
spring.cloud.nacos.discovery.server