Spring为咱们提供的多环境启动mysql
1. 配置类,注入三个不一样环境的数据源,并加上注解spring
/** * 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. 测试类,假设开启生产的数据源sql
/** * 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. 说明spa
@Profile不只能够加在Bean上,还能够加在到类上,表示这个类所属的环境code
还有一种方式让环境生效,配置虚拟机参数,-Dspring.profiles.active=prodblog