Spring @Profile注解實現(xiàn)多環(huán)境配置
一 前言
springboot中使用多環(huán)境開發(fā)如此簡單,你想知道spring中是如何實現(xiàn)的么?一起來學習吧!!你為什么不好好學習基礎,面試一直被diss呢?說到底還不是你認為都會了,其實你都不會,一問三不知!!
二 @profile實現(xiàn)多環(huán)境配置
2.1 @profile配置
使用@profile注解的目的是未了多環(huán)境開發(fā),比如開發(fā)環(huán)境使用dev, 生產(chǎn)環(huán)境使用prod,就可以使用@Profile注解實現(xiàn)不同的開發(fā)環(huán)境使用不同的數(shù)據(jù)源;
@profile注解 使用說明:
spring3.2之前 @Profile注解用在類上
spring3.2 之后 @Profile注解用在 方法上
/** * @Author lsc * <p>spring3.2之前 @Profile注解用在類上 * spring3.2 之后 @Profile注解用在 方法上 * </p> */@Configurationpublic 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 p:driverClassName='com.mysql.jdbc.Driver' p:url='jdbc:mysql://localhost:3306/zszxzb' p:username='root' p:password='1234'/></beans><beans profile='prod'> <bean 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)//創(chuàng)建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); }}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關文章:
1. 用css截取字符的幾種方法詳解(css排版隱藏溢出文本)2. jsp實現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法3. jsp網(wǎng)頁實現(xiàn)貪吃蛇小游戲4. ASP 信息提示函數(shù)并作返回或者轉向5. CSS hack用法案例詳解6. asp中response.write("中文")或者js中文亂碼問題7. 將properties文件的配置設置為整個Web應用的全局變量實現(xiàn)方法8. PHP設計模式中工廠模式深入詳解9. 刪除docker里建立容器的操作方法10. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明
