三、讀取外部的資源配置文件並配置數據庫連接池
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
<!-- 定義數據源 --> <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代碼的形式而已。