您的位置:

Spring Boot P 全能编程开发指南

一、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 配置文件的加载顺序如下:

  1. 命令行参数。
  2. 来自 SPRING_APPLICATION_JSON 的属性。
  3. JNDI 属性 from java:comp/env。
  4. Java 系统属性:
    • systemProperties
    • systemEnvironment
  5. OS 环境变量。
  6. ~/config/application.properties。
  7. ~/config/application.yml。
  8. classpath:/config/application.properties。
  9. classpath:/config/ application.yml。
  10. classpath:/application.properties。
  11. classpath:/application.yml。

七、SpringBoot 配置加载的方法有哪些

1、在 SpringBoot 开发过程中。常用的 SpringBoot 配置加载方法如下:

  1. 使用 @Value 注解为属性自动注入值
  2. 通过 @ConfigurationProperties 注解将配置文件内容自动注入 Bean
  3. 通过 Environment 注入值
  4. 通过 @PropertySource 注解注入值

八、Spring Boot P 配置多数据源

1、在 Spring Boot P 开发中,我们常用的多数据源配置方法有如下几种:

  1. 编写配置类,将不同数据源的连接信息封装成参数,注入到数据库链接池中
  2. 使用 Atomikos 分布式事务管理器
  3. 使用 HikariCp 数据库连接池
  4. 使用 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 应用开发框架,它可以快速帮助我们构建出高效、安全、易于维护的应用程序。