标签:mysqli test mysql config new jdb active ring esc
Spring为我们提供的多环境启动
1. 配置类,注入三个不同环境的数据源,并加上注解
/** * description: 以下准备了三套不同环境的数据源 * * @author 70KG * @date 2018/12/17 */ @Configuration public class MyConfig { @Bean @Profile("dev") public MySqlInfo mySqlInfoDev() { MySqlInfo mySqlInfo = new MySqlInfo(); mySqlInfo.setUserName("zhangsan"); mySqlInfo.setPassWord("1111"); mySqlInfo.setDriver("com.mysql.jdbc.driver"); System.out.println("dev数据源被注入。。。。。。"); return mySqlInfo; } @Bean @Profile("test") public MySqlInfo mySqlInfoTest() { MySqlInfo mySqlInfo = new MySqlInfo(); mySqlInfo.setUserName("lisi"); mySqlInfo.setPassWord("2222"); mySqlInfo.setDriver("com.mysql.jdbc.driver"); System.out.println("test数据源被注入。。。。。。"); return mySqlInfo; } @Bean @Profile("prod") public MySqlInfo mySqlInfoProd() { MySqlInfo mySqlInfo = new MySqlInfo(); mySqlInfo.setUserName("wangwu"); mySqlInfo.setPassWord("3333"); mySqlInfo.setDriver("com.mysql.jdbc.driver"); System.out.println("prod数据源被注入。。。。。。"); return mySqlInfo; } }
2. 测试类,假设开启生产的数据源
/** * description * * @author 70KG * @date 2018/12/17 */ public class Test01 { @Test public void test() { // 无参构造创建容器 AnnotationConfigApplicationContext ac = new AnnotationConfigApplicationContext(); // 读取配置文件,并属性赋值 ac.register(MyConfig.class); ac.getEnvironment().setActiveProfiles("prod"); // 刷新容器 ac.refresh(); } }
3. 结果
prod数据源被注入。。。。。。
4. 说明
@Profile不仅可以加在Bean上,还可以加在到类上,表示这个类所属的环境
还有一种方式让环境生效,配置虚拟机参数,-Dspring.profiles.active=prod
标签:mysqli test mysql config new jdb active ring esc
原文地址:https://www.cnblogs.com/zhangjianbing/p/10130501.html