我们在做项目开发的时候,生产环境和测试环境的一些配置可能会不一样,有时候一些功能也可能会不一样,所以我们可能会在上线的时候手工修改这些配置信息。但是Spring中为我们提供了Profile这个功能。我们只需要在启动的时候添加一个虚拟机参数,激活自己环境所要用的Profile就可以了。下面举个例子来说明一下:
首先我们先创建一个bean,用来测试是不是从不同的配置文件中取的值。代码如下(省略getter/setter):
@ConfigurationProperties("profile.test") @Component public class ProfileDomain implements Serializable { private static final long serialVersionUID = 2092752356451204202L; /** * 用户名 */ private String userName; /** * 密码 */ private String passWord; }接着我们在resources下面建立两个properties文件。
application-dev.properties用来存放的时候开发环境的配置信息,application-prod.properties用来存放的是生产环境的配置信息。内容分别如下:
application-dev.properties:
profile.test.userName=\u6211\u662f\u5f00\u53d1\u73af\u5883 profile.test.passWord=this is development environmentapplication-prod.properties:
profile.test.userName=\u6211\u662f\u751f\u4ea7\u73af\u5883 profile.test.passWord=this is production environment我们写个Controller来测试一下:
@RestController public class ProfileController { @Autowired private ProfileDomain profileDomain; @RequestMapping("testProfile") public ProfileDomain testProfile() { return profileDomain; } }我们用命令行启动一下(注意我们这里加了个参数 --spring.profiles.active=dev):
java -jar LearnSpringBoot-0.0.1-SNAPSHOT.jar --spring.profiles.active=dev下面我们访问一下:http://localhost:8003/testProfile,输出结果如下:
从输出结果中我们可以看出,输出的内容是application-dev.properties中的配置信息。下面我们用另外一个命令参数启动一下:
java -jar LearnSpringBoot-0.0.1-SNAPSHOT.jar --spring.profiles.active=prod我们还是用上面的请求访问一下:
http://localhost:8003/testProfile,输出结果如下:
从上面的输出结果中我们可以看到我们在启动SpringBoot的时候所启用的profile,它就会从不同的配置文件中加载配置项。另外还可以增加虚拟机参数:-Dspring.profiles.active=prod的方式来激活不同的profile。也可以在SpringBoot默认的或者指定的配置文件中增加profile的激活项。如:spring.profiles.active=dev。
有时候我们可能还会有这样的需求,生产环境或者开发环境我们所看到的功能是不同的,也需要我们根据配置项来激活不同的功能。
首先我们先定义一个Service的接口:
public interface ProfileService { String getProfileDomain(); }如果spring.profiles.active的值是prod的时,它的实现类如下:
@Profile(value = "prod") @Service public class ProfileProdServiceImpl implements ProfileService { public ProfileProdServiceImpl() { System.out.println("我是生产环境。。。。。"); } @Override public String getProfileDomain() { StringBuilder sb = new StringBuilder(); sb.append("我在生产环境,").append("我可以吃鸡鸭鱼牛羊肉。。。。"); return sb.toString(); } }如果spring.profiles.active的值是dev的时,它的实现类如下:
@Profile(value = "dev") @Service public class ProfileDevServiceImpl implements ProfileService { public ProfileDevServiceImpl() { System.out.println("我是开发环境。。。。。"); } @Override public String getProfileDomain() { StringBuilder sb = new StringBuilder(); sb.append("我在开发环境,").append("我只能吃加班餐:大米饭。。。。"); return sb.toString(); } }下面我们来测试一下,在刚才的Controller类中注入ProfileService,代码如下:
@RestController public class ProfileController { @Autowired private ProfileDomain profileDomain; @Autowired private ProfileService profileService; @RequestMapping("testProfile") public ProfileDomain testProfile() { return profileDomain; } @RequestMapping("testProfile2") public String testProfile2() { return profileService.getProfileDomain(); } }当我们的spring.profiles.active为prod的时候:请求如下:http://localhost:8003/testProfile2,输出如下:
当我们的spring.profiles.active为dev的时候:请求如下:http://localhost:8003/testProfile2,输出如下:
我们在根据环境进行功能切换的类上加上@Profile注解,这样就可以根据所激活的不同的环境,注入不同的实现类。
这里需要注意一下:如果用了@Profile这个注解,在配置项中找不到@Profile中的值的话,在系统启动的时候是会报错的。