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

小编这次要给大家分享的是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") 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中配置,示例如下


    


    

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

看完这篇关于Spring @Profile注解如何实现多环境配置的文章,如果觉得文章内容写得不错的话,可以把它分享出去给更多人看到。


当前题目:Spring@Profile注解如何实现多环境配置
链接地址:http://pcwzsj.com/article/pdeegg.html