SpringBoot學習(三)-->Spring的Java配置方式之讀取外部的資源配置文件並配置數據庫連接池


三、讀取外部的資源配置文件並配置數據庫連接池

1、讀取外部的資源配置文件

通過@PropertySource可以指定讀取的配置文件,通過@Value注解獲取值,具體用法:

@Configuration //通過該注解來表明該類是一個Spring的配置,相當於一個xml文件
@ComponentScan(basePackages = "cn.mmzs.springboot") //配置掃描包
@PropertySource(value= {"classpath:jdbc.properties"})
public class SpringConfig {
    
    @Value("${jdbc.url}")
    private String jdbcUrl;

    @Bean // 通過該注解來表明是一個Bean對象,相當於xml中的<bean>
    public UserDao getUserDAO(){
        return new UserDao(); // 直接new對象做演示
    }
    
}

思考:

1)、  如何配置多個配置文件?

//獲取多個資源文件
@PropertySource(value= {"classpath:jdbc.properties","classpath:log4j.properties","xxx"})

2)、如果配置的配置文件不存在會怎么樣?

//使用,ignoreResourceNotFound設置為true來進行忽略沒有找到的配置文件
@PropertySource(value= {"classpath:jdbc.properties"},ignoreResourceNotFound = true)//獲取一個資源文件
@PropertySource(value= {"classpath:jdbc.properties","classpath:log4j.properties","xxx"},ignoreResourceNotFound = true)//獲取多個資源文件

2、配置數據庫連接池

a、導入依賴

<!-- 連接池 -->
<dependency>
    <groupId>com.jolbox</groupId>
    <artifactId>bonecp-spring</artifactId>
    <version>0.8.0.RELEASE</version>
</dependency>

b、利用xml文件配置時:

 1 jdbc.driverClassName=com.mysql.jdbc.Driver
 2 #數據庫的路徑
 3 #url=jdbc:mysql://localhost:3306/springboot
 4 jdbc.url=jdbc:mysql://localhost:3306/house
 5 jdbc.username=root
 6 jdbc.password=123456
 7 #定義初始連接數
 8 initialSize=0
 9 #定義最大連接數
10 maxActive=20
11 #定義最大空閑
12 maxIdle=20
13 #定義最小空閑
14 minIdle=1
15 #定義最長等待時間
16 maxWait=60000
jdbc.properties
     <!-- 定義數據源 -->
    <bean id="dataSource" class="cn.mmzs.springboot.javaconfig"
        destroy-method="close">
        <!-- 數據庫驅動 -->
        <property name="driverClass" value="${jdbc.driverClassName}" />
        <!-- 相應驅動的jdbcUrl -->
        <property name="jdbcUrl" value="${jdbc.url}" />
        <!-- 數據庫的用戶名 -->
        <property name="username" value="${jdbc.username}" />
        <!-- 數據庫的密碼 -->
        <property name="password" value="${jdbc.password}" />
        <!-- 檢查數據庫連接池中空閑連接的間隔時間,單位是分,默認值:240,如果要取消則設置為0 -->
        <property name="idleConnectionTestPeriod" value="60" />
        <!-- 連接池中未使用的鏈接最大存活時間,單位是分,默認值:60,如果要永遠存活設置為0 -->
        <property name="idleMaxAge" value="30" />
        <!-- 每個分區最大的連接數 -->
        <!-- 
            判斷依據:請求並發數
         -->
        <property name="maxConnectionsPerPartition" value="100" />
        <!-- 每個分區最小的連接數 -->
        <property name="minConnectionsPerPartition" value="5" />
    </bean>

c、參考xml配置改造成java配置方式:

@Configuration // 通過該注解來表明該類是一個Spring的配置,相當於一個xml文件
@ComponentScan(basePackages = "cn.mmzs.springboot") // 配置掃描包
@PropertySource(value = { "classpath:jdbc.properties" }, ignoreResourceNotFound = true)
public class SpringConfig {

    @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;
    }

}

思考: 如何使用該DataSource對象?

該咋用咋用,該注入就注入,該引用就引用,和之前一樣,這里只是將資源的配置方式從xml文件形式修改成了java代碼的形式而已。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM