SpringBoot之开启Profile

我们在做项目开发的时候,生产环境和测试环境的一些配置可能会不一样,有时候一些功能也可能会不一样,所以我们可能会在上线的时候手工修改这些配置信息。但是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文件。

SpringBoot之开启Profile
application-dev.properties用来存放的时候开发环境的配置信息,application-prod.properties用来存放的是生产环境的配置信息。内容分别如下:

application-dev.properties:

profile.test.userName=\u6211\u662f\u5f00\u53d1\u73af\u5883
profile.test.passWord=this is development environment
application-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,输出结果如下:

SpringBoot之开启Profile

从输出结果中我们可以看出,输出的内容是application-dev.properties中的配置信息。下面我们用另外一个命令参数启动一下:

java -jar LearnSpringBoot-0.0.1-SNAPSHOT.jar --spring.profiles.active=prod
我们还是用上面的请求访问一下:

http://localhost:8003/testProfile,输出结果如下:

SpringBoot之开启Profile

从上面的输出结果中我们可以看到我们在启动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,输出如下:

SpringBoot之开启Profile

当我们的spring.profiles.active为dev的时候:请求如下:http://localhost:8003/testProfile2,输出如下:SpringBoot之开启Profile

我们在根据环境进行功能切换的类上加上@Profile注解,这样就可以根据所激活的不同的环境,注入不同的实现类。
这里需要注意一下:如果用了@Profile这个注解,在配置项中找不到@Profile中的值的话,在系统启动的时候是会报错的。

上一篇:下列软件包有未满足的依赖关系: gsettings-desktop-schemas : 破坏: mutter (< 3.


下一篇:使用metaweblog API实现通用博客发布 之 API测试