2.1 @profile配置
使用@profile註解的目的是未了多環境開發,比如開發環境使用dev, 生產環境使用prod,就可以使用@Profile註解實現不同的開發環境使用不同的數據源;
@profile註解 使用說明:
- spring3.2之前 @Profile註解用在類上
- spring3.2 之後 @Profile註解用在 方法上
/**
* @Author lsc
* <p>spring3.2之前 @Profile註解用在類上
* spring3.2 之後 @Profile註解用在 方法上
* </p>
*/
@Configuration
public class DataSourceConfig {
@Bean
@Profile("dev")
public DataSource devDataSource() {
System.out.println(" dev DataSource !!");
BasicDataSource basicDataSource = new BasicDataSource();
basicDataSource.setDriverClassName("com.mysql.jdbc.Driver");
basicDataSource.setUrl("jdbc:mysql://localhost:3308/zszxz");
basicDataSource.setUsername("root");
basicDataSource.setPassword("1234");
return basicDataSource;
}
@Bean
@Profile("prod")
public DataSource prodDataSource() {
System.out.println(" prod DataSource !!");
BasicDataSource basicDataSource = new BasicDataSource();
basicDataSource.setDriverClassName("com.mysql.jdbc.Driver");
basicDataSource.setUrl("jdbc:mysql://localhost:3306/zszxz");
basicDataSource.setUsername("root");
basicDataSource.setPassword("1234");
return basicDataSource;
}
}
如果你是在xml中配置,示例如下
<beans profile="dev">
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
p:driverClassName="com.mysql.jdbc.Driver"
p:url="jdbc:mysql://localhost:3306/zszxzb"
p:username="root"
p:password="1234"/>
</beans>
<beans profile="prod">
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
p:driverClassName="com.mysql.jdbc.Driver"
p:url="jdbc:mysql://localhost:3306/zszxzb"
p:username="root"
p:password="1234"/>
</beans>
2.2 激活方式
激活方式一
- spring.profiles.active 激活方式
- 如果 spring.profiles.active 未配置, 使用spring.profiles.default激活方式
- 如果前面都未配置,就會加載沒有定義在profile中的bean;
激活方式二
在web.xml 中配置
<context-param>
<param-name>spring.profiles.active</param-name>
<param-value>dev</param-value>
</context-param>
<servlet>
<servlet-name>zszxzServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>spring.profiles.default</param-name>
<param-value>dev</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>zszxzServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
激活方式三
在類上使用@ActiveProfiles
註解
測試如下
@RunWith(SpringJUnit4ClassRunner.class)//創建spring應用上下文
@ContextConfiguration(classes= DataSourceConfig.class)//加載配置類
@ActiveProfiles("dev")
public class ProfileTest {
@Autowired
private DataSource dataSource;
@Test
public void sheetTest(){
JdbcTemplate jdbc = new JdbcTemplate(dataSource);
List<String> query = jdbc.query("select * from customer", new RowMapper<String>() {
@Override
public String mapRow(ResultSet rs, int rowNum) throws SQLException {
return rs.getLong("id") + ":" + rs.getString("customer_name");
}
});
// [19:知識追尋者, 20:知識追尋者, 21:知識追尋者, 22:知識追尋者, 23:知識追尋者]
System.out.println(query);
}
}