Spring @Profile注解实现多环境配置

网友投稿 434 2022-12-09


Spring @Profile注解实现多环境配置

一 前言

springboot中使用多环境开发如此简单,你想知道spring中是如何实现的么?一起来学习吧!!你为什么不好好学习基础,面试一直被diss呢?说到底还不是你认为都会了,其实你都不会,一问三不知!!

二 @profile实现多环境配置

2.1 @profile配置

使用@profile注解的目的是未了多环境开发,比如开发环境使用dev, 生产环境使用prod,就可以使用@Profile注解实现不同的开发环境使用不同的数据源;

@profile注解 使用说明:

spring3.2之前 @Profile注解用在类上

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

/**

* @Author lsc

*

spring3.2之前 @Profile注解用在类上

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

*

*/

@Configuration

public class DataSourceConfig {

@Bean

@Profile("dev")http://

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中配置,示例如下

p:driverClassName="com.mysql.jdbc.Driver"

p:url="jdbc:mysql://localhost:3306/zszxzb"

p:username="root"

p:password="1234"/>

p:driverClassName="com.mysql.jdbc.Driver"

p:url="jdbc:mysql://localhost:3306/zszxzb"

p:username="root"

p:password="1234"/>

2.2 激活方式

激活方式一

spring.profiles.active 激活方式

如果 spring.profiles.active 未配置, 使用spring.profiles.default激活方式

如果前面都为配置,就会加载没有定义在profile中的bean;

激活方式二

在web.xml 中配置

spring.profiles.active

dev

zszxzServlet

org.springframework.web.servlet.DispatcherServlet

spring.profiles.default

dev

1

zszxzServlet

/

激活方式三

在类上使用@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 query = jdbc.query("select * from customer", new RowMapper() {

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

}

}

p:driverClassName="com.mysql.jdbc.Driver"

p:url="jdbc:mysql://localhost:3306/zszxzb"

p:username="root"

p:password="1234"/>

p:driverClassName="com.mysql.jdbc.Driver"

p:url="jdbc:mysql://localhost:3306/zszxzb"

p:username="root"

p:password="1234"/>

2.2 激活方式

激活方式一

spring.profiles.active 激活方式

如果 spring.profiles.active 未配置, 使用spring.profiles.default激活方式

如果前面都为配置,就会加载没有定义在profile中的bean;

激活方式二

在web.xml 中配置

spring.profiles.active

dev

zszxzServlet

org.springframework.web.servlet.DispatcherServlet

spring.profiles.default

dev

1

zszxzServlet

/

激活方式三

在类上使用@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 query = jdbc.query("select * from customer", new RowMapper() {

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

}

}

p:driverClassName="com.mysql.jdbc.Driver"

p:url="jdbc:mysql://localhost:3306/zszxzb"

p:username="root"

p:password="1234"/>

2.2 激活方式

激活方式一

spring.profiles.active 激活方式

如果 spring.profiles.active 未配置, 使用spring.profiles.default激活方式

如果前面都为配置,就会加载没有定义在profile中的bean;

激活方式二

在web.xml 中配置

spring.profiles.active

dev

zszxzServlet

org.springframework.web.servlet.DispatcherServlet

spring.profiles.default

dev

1

zszxzServlet

/

激活方式三

在类上使用@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 query = jdbc.query("select * from customer", new RowMapper() {

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

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring装配bean方法实例总结
下一篇:Springcloud微服务架构基础知识解析
相关文章

 发表评论

暂时没有评论,来抢沙发吧~