在 Spring Boot 中,可以通过在 application.properties 或 application.yml 文件中设置数据库配置来实现静态加载数据库配置。但是,如果要实现动态加载数据库配置,可以使用 Spring Boot 的动态配置特性。
以下是实现动态加载数据库配置的步骤:
添加相关依赖 在 pom.xml 文件中添加必要的依赖,包括 Spring Boot Starter、Spring Boot DevTools、Spring Boot Configuration Processor 等。
创建配置类
创建一个类,用于加载数据库配置,例如 DatabaseConfig.java。在该类中,使用 @ConfigurationProperties
注解来绑定配置文件中的属性。
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component
@ConfigurationProperties(prefix = "database")
public class DatabaseConfig {
private String url;
private String username;
private String password;
// getters and setters
}
配置文件 在 application.properties 或 application.yml 文件中,添加数据库配置的属性。
application.properties:
database.url=jdbc:mysql://localhost:3306/mydb
database.username=root
database.password=root
application.yml:
database:
url: jdbc:mysql://localhost:3306/mydb
username: root
password: root
主类中加载配置类
在主类中,使用 @EnableConfigurationProperties
注解来加载配置类。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
@SpringBootApplication
@EnableConfigurationProperties(DatabaseConfig.class)
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
现在,就可以在代码中注入 DatabaseConfig 类,并使用其中的属性。
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class MyService {
private final DatabaseConfig databaseConfig;
@Autowired
public MyService(DatabaseConfig databaseConfig) {
this.databaseConfig = databaseConfig;
}
public void doSomething() {
String url = databaseConfig.getUrl();
String username = databaseConfig.getUsername();
String password = databaseConfig.getPassword();
// 使用数据库配置执行操作
}
}
这样,就可以动态加载数据库配置。当配置文件中的数据库配置发生变化时,无需重启应用程序,配置的变化会自动生效。