久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Spring @Profile注解實(shí)現(xiàn)多環(huán)境配置

瀏覽:2日期:2023-09-10 09:19:11

一 前言

springboot中使用多環(huán)境開(kāi)發(fā)如此簡(jiǎn)單,你想知道spring中是如何實(shí)現(xiàn)的么?一起來(lái)學(xué)習(xí)吧??!你為什么不好好學(xué)習(xí)基礎(chǔ),面試一直被diss呢?說(shuō)到底還不是你認(rèn)為都會(huì)了,其實(shí)你都不會(huì),一問(wèn)三不知??!

二 @profile實(shí)現(xiàn)多環(huán)境配置

2.1 @profile配置

使用@profile注解的目的是未了多環(huán)境開(kāi)發(fā),比如開(kāi)發(fā)環(huán)境使用dev, 生產(chǎn)環(huán)境使用prod,就可以使用@Profile注解實(shí)現(xiàn)不同的開(kāi)發(fā)環(huán)境使用不同的數(shù)據(jù)源;

@profile注解 使用說(shuō)明:

spring3.2之前 @Profile注解用在類(lèi)上

spring3.2 之后 @Profile注解用在 方法上

/** * @Author lsc * <p>spring3.2之前 @Profile注解用在類(lèi)上 * 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激活方式 如果前面都為配置,就會(huì)加載沒(méi)有定義在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>

激活方式三

在類(lèi)上使用@ActiveProfiles注解

測(cè)試如下

@RunWith(SpringJUnit4ClassRunner.class)//創(chuàng)建spring應(yīng)用上下文@ContextConfiguration(classes= DataSourceConfig.class)//加載配置類(lèi)@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:知識(shí)追尋者, 20:知識(shí)追尋者, 21:知識(shí)追尋者, 22:知識(shí)追尋者, 23:知識(shí)追尋者] System.out.println(query); }}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 贵南县| 磴口县| 富蕴县| 灵武市| 伊通| 永仁县| 周至县| 葵青区| 垦利县| 罗定市| 盐源县| 留坝县| 巴彦县| 灵宝市| 安徽省| 甘孜| 宝鸡市| 清镇市| 双桥区| 新安县| 金华市| 贵阳市| 鱼台县| 商河县| 黔江区| 牡丹江市| 林西县| 临泉县| 咸宁市| 东城区| 平阳县| 靖安县| 唐海县| 三都| 九龙县| 科技| 定远县| 平利县| 绥江县| 铜鼓县| 吴江市|