SpringBoot读取外部的资源配置文件及配置数据库连接池

项目下载地址:https://download.csdn.net/download/weixin_39549656/10287664
通过@PropertySource可以指定读取的配置文件,通过@Value注解获取值,具体用法:

@Configuration //通过该注解来表明该类是一个Spring的配置,相当于一个xml文件
@ComponentScan(basePackages = "cn.itcast.springboot.javaconfig") //配置扫描包
@PropertySource(value= {"classpath:jdbc.properties"})//如果是多个配置文件@PropertySource(value= {"classpath:jdbc.properties","",""})
public class SpringConfig {

    @Value("${jdbc.url}")
    private String jdbcUrl;

    @Bean // 通过该注解来表明是一个Bean对象,相当于xml中的
    public UserDAO getUserDAO(){
        return new UserDAO(); // 直接new对象做演示
    }

}

1.配置多个配置文件
这里写图片描述
2.如果配置的配置文件不存在会怎么样?
SpringBoot读取外部的资源配置文件及配置数据库连接池_第1张图片

实践:配置数据库连接池

导入依赖:


        <dependency>
            <groupId>com.jolboxgroupId>
            <artifactId>bonecp-springartifactId>
            <version>0.8.0.RELEASEversion>
        dependency>

之前的Spring xml配置:

 
    <bean id="dataSource" class="com.jolbox.bonecp.BoneCPDataSource"
        destroy-method="close">
        
        <property name="driverClass" value="${jdbc.driverClassName}" />
        
        <property name="jdbcUrl" value="${jdbc.url}" />
        
        <property name="username" value="${jdbc.username}" />
        
        <property name="password" value="${jdbc.password}" />
        
        <property name="idleConnectionTestPeriod" value="60" />
        
        <property name="idleMaxAge" value="30" />
        
        
        <property name="maxConnectionsPerPartition" value="100" />
        
        <property name="minConnectionsPerPartition" value="5" />
    bean>

参考xml配置改造成java配置方式:

 @Value("${jdbc.url}")
    private String jdbcUrl;

    @Value("${jdbc.driverClassName}")
    private String jdbcDriverClassName;

    @Value("${jdbc.username}")
    private String jdbcUsername;

    @Value("${jdbc.password}")
    private String jdbcPassword;

    @Bean(destroyMethod = "close")//作用是当数据库连接不使用的时候,就把该连接重新放到数据池中,方便下次使用调用. 
    public DataSource dataSource() {
        BoneCPDataSource boneCPDataSource = new BoneCPDataSource();
        // 数据库驱动
        boneCPDataSource.setDriverClass(jdbcDriverClassName);
        // 相应驱动的jdbcUrl
        boneCPDataSource.setJdbcUrl(jdbcUrl);
        // 数据库的用户名
        boneCPDataSource.setUsername(jdbcUsername);
        // 数据库的密码
        boneCPDataSource.setPassword(jdbcUsername);
        // 检查数据库连接池中空闲连接的间隔时间,单位是分,默认值:240,如果要取消则设置为0
        boneCPDataSource.setIdleConnectionTestPeriodInMinutes(60);
        // 连接池中未使用的链接最大存活时间,单位是分,默认值:60,如果要永远存活设置为0
        boneCPDataSource.setIdleMaxAgeInMinutes(30);
        // 每个分区最大的连接数
        boneCPDataSource.setMaxConnectionsPerPartition(100);
        // 每个分区最小的连接数    
        boneCPDataSource.setMinConnectionsPerPartition(5);
        return boneCPDataSource;
}

你可能感兴趣的:(Springboot)