一、SpringBoot 配置多数据源 druid
1、SpringBoot 配置多数据源是非常常见的需求,为了高效地管理不同数据源的连接,我们可以使用 Druid 数据库连接池。
@Configuration public class DruidDBConfig { private Logger logger = LoggerFactory.getLogger(DruidDBConfig.class); @Autowired private DruidProperties druidProperties; @Bean(name="primaryDataSource") @Primary public DruidDataSource primaryDataSource() { return initDataSource(druidProperties.getPrimary()); } @Bean(name="secondaryDataSource") public DruidDataSource secondaryDataSource() { return initDataSource(druidProperties.getSecondary()); } private DruidDataSource initDataSource(DruidProperties.DruidDataSourceProperties properties) { DruidDataSource druidDataSource = new DruidDataSource(); druidDataSource.setUrl(properties.getUrl()); druidDataSource.setUsername(properties.getUsername()); druidDataSource.setPassword(properties.getPassword()); druidDataSource.setDriverClassName(properties.getDriverClassName()); druidDataSource.setInitialSize(properties.getInitialSize()); druidDataSource.setMinIdle(properties.getMinIdle()); druidDataSource.setMaxActive(properties.getMaxActive()); druidDataSource.setMaxWait(properties.getMaxWait()); return druidDataSource; } }
2、在 application.yml 中配置数据源信息
# DataSource - Primary spring.datasource.primary.url=jdbc:mysql://localhost:3306/primary_db spring.datasource.primary.username=root spring.datasource.primary.password=admin spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver # DataSource - Secondary spring.datasource.secondary.url=jdbc:mysql://localhost:3307/secondary_db spring.datasource.secondary.username=root spring.datasource.secondary.password=admin spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver
二、SpringBoot 配置文件
1、SpringBoot 的配置文件 application.yml 使用 YAML 格式,简单易读,更容易维护。
2、YAML 文件定义方式比较灵活,支持各种数据类型,包括:标量(字符串,布尔值,数字),列表,映射等。
3、一个示例配置文件:
spring: application: name: MyApp datasource: url: jdbc:mysql://localhost:3306/my_app_db username: root password: admin driver-class-name: com.mysql.jdbc.Driver mail: host: smtp.gmail.com username: myapp@gmail.com password: mydivxsammiyvocc properties: mail: smtp: auth: true starttls: enable: true server: port: 8080
三、SpringBoot 批量新增数据
1、在 SpringBoot 开发过程中,有时需要新增批量数据。使用 JDK8 Stream 语法,代码更加简洁高效。
@Service public class BatchInsertService { @Autowired private JdbcTemplate jdbcTemplate; public void batchInsert(List<Student> students) { String sql = "insert into student(name, age) values(?,?)"; int[][] args = jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() { @Override public void setValues(PreparedStatement preparedStatement, int i) throws SQLException { preparedStatement.setString(1, students.get(i).getName()); preparedStatement.setInt(2, students.get(i).getAge()); } @Override public int getBatchSize() { return students.size(); } }); logger.info("Inserted {} students", args.length); } }
四、SpringBoot 配置文件密码加密
1、在 SpringBoot 开发中,我们经常需要将数据库连接的密码存储在配置文件中。但是,这可能会导致密码泄露。
2、SpringBoot 明文密码加密方式,修改 application.yml 如下:
spring: datasource: username: myname password: '{cipher}eb8cfcd691faff66f3218889698f1472cd43078d7673dffc84c5a754839f7429'
3、加密配置,修改 application.yml 如下:
encrypt: key-store: location: file:///${user.home}/.keystore password: mysecretpassword alias: mykey secret: mysecretkey
五、SpringBoot 配置文件 project
1、SpringBoot 可以自动生成、引导和配置新项目。Spring Initializer 生成项目框架,并提供需要的依赖项列表。
2、http://start.spring.io
六、SpringBoot 配置文件加载顺序详解
1、SpringBoot 配置文件的加载顺序如下:
- 命令行参数。
- 来自 SPRING_APPLICATION_JSON 的属性。
- JNDI 属性 from java:comp/env。
- Java 系统属性:
- systemProperties
- systemEnvironment
- OS 环境变量。
- ~/config/application.properties。
- ~/config/application.yml。
- classpath:/config/application.properties。
- classpath:/config/ application.yml。
- classpath:/application.properties。
- classpath:/application.yml。
七、SpringBoot 配置加载的方法有哪些
1、在 SpringBoot 开发过程中。常用的 SpringBoot 配置加载方法如下:
- 使用 @Value 注解为属性自动注入值
- 通过 @ConfigurationProperties 注解将配置文件内容自动注入 Bean
- 通过 Environment 注入值
- 通过 @PropertySource 注解注入值
八、Spring Boot P 配置多数据源
1、在 Spring Boot P 开发中,我们常用的多数据源配置方法有如下几种:
- 编写配置类,将不同数据源的连接信息封装成参数,注入到数据库链接池中
- 使用 Atomikos 分布式事务管理器
- 使用 HikariCp 数据库连接池
- 使用 Spring Boot P 自带多数据源配置方法
九、SpringBoot 配置文件路径
1、SpringBoot 配置文件放在 src/main/resources 下,默认会被编译到 classpath 路径下。
2、在配置文件中,可以通过 ${} 获取系统环境和变量。
spring: profiles: active: ${SPRING_PROFILE_ACTIVE:dev}
十、SpringBoot 配置类和配置文件选取
1、对于 SpringBoot 的配置,我们可以选择 Java 配置类或者 YML/Properties 配置文件两种方式。
2、通常情况下,我们选择使用 YML/Properties 配置文件。
3、在某些特殊情况下,我们可能会选择使用 Java 配置类,例如我们需要通过代码来动态创建、修改配置项。
结语
以上就是 Spring Boot P 全能编程开发指南的介绍。Spring Boot P 是一个快速开发、简化部署、轻量级的 Java Web 应用开发框架,它可以快速帮助我们构建出高效、安全、易于维护的应用程序。