스프링에서는 Profile을 지정하여 어플리케이션의 구성(Configuration)을 Profile별로 가져갈 수 있도록 한다. 즉, 같은 소스코드를 두고 로컬환경, 개발환경, 운영환경별로 다른 구성(DB 접속정보, 업로드 파일의 저장위치 등)으로 실행할 수 있다.
@Profile
다르게 가져갈 구성은 @Component, @Configuration, @ConfigurationProperties 애노테이션에 @Profile을 마킹하여 지정하고, 어플리케이션 실행시 spring.profiles.active 프로퍼티로 프로파일을 지정하면 해당 프로파일이 적용된 빈만 등록된다.
아래는 test 프로파일을 적용해본 예시이다. @Component를 마킹하여 빈으로 등록될 클래스에 @Profile을 마킹했다. 이러면 정의한 프로파일에서만 빈으로 등록된다.
@Component
@Profile("test") // 이 클래스는 [test]프로파일에서만 빈으로 등록된다.
public class TestBean {
}
@Component
public class Sample implements ApplicationRunner {
@Autowired(required = false)
TestBean testBean;
@Override
public void run(ApplicationArguments args) throws Exception {
System.out.println("=====================================================");
System.out.println("test 프로파일에서만 등록되는 빈 : " + testBean);
System.out.println("=====================================================");
}
}
테스트시 --spring.profiles.active=test 옵션을 주고 실행시 다음과 같이 콘솔에 남으며 TestBean 빈이 null 값이 아니라 등록 되었음을 확인할 수 있다.
===================================================== test 프로파일에서만 등록되는 빈 : com.yang.wind.TestBean@50fb33a ===================================================== |
만일 --spring.profiles.active=test 옵션을 빼고 실행하여 디폴트 프로파일로 실행하거나 --spring.profiles.active=dev 처럼 다른 프로파일을 지정하면 null 값으로 콘솔에 남는다.
Profile - Property File
스프링부트는 활성화 된 프로파일에 따라서 지정된 프로퍼티 파일을 읽는다.
즉 어떠한 프로파일도 활성화 하지 않으면 디폴트 프로퍼티 파일로 application.properties를 읽지만 test 프로파일을 활성화 하면 프로퍼티 파일로 application-test.properties를 읽어온다. 하지만 application-test.properties만 읽는것이 아니라 application.properties 파일도 같이 읽으며 중복된 값이 profile이 정의된 파일로 오버라이드 된다.
- XXX 프로파일 활성화시 설정파일 : application.properties, application.yml, application-XXX.properties, application-XXX.yml
프로파일에 따라 어떻게 설정파일을 읽는지 알기위해 간단한 테스트를 해본다.
3개의 프로퍼티 파일을 작성 후 활성화한 프로파일에 따라 어떻게 값이 오버라이드 되는지 알아본다.
# application.yml 파일 -> 프로파일이 설정되지 않음. 우선순위가 낮아 프로파일 설정시 오버라이드 된다. profile-common: name: defaultnameCommon defaultonly: name: defualtname |
# application-dev.yml 파일 -> dev 프로파일이 활성화시 우선순위가 높은 프로퍼티 파일 profile-common: name: devnameCommon devonly: name: devname |
# application-test.yml -> test 프로파일이 활성화시 우선순위가 높은 프로퍼티 파일 profile-common: name: testnameCommon testonly: name: testname |
- profile-common.name는 모든 프로퍼티 파일이 공통으로 가진 프로퍼티이고, 각 파일마다 개별로 가지고있는 프로퍼티도 있다.
- test 프로파일을 활성화하고 어플리케이션을 기동하면 공통속성인 profile-common.name은 프로파일 프로퍼티 파일(application-test.yml)이 나머지를 오버라이드하여 testnameCommon이 값이 된다.
- application-test.yml 뿐만 아니라 디폴트 프로파일 파일인 application.yml 또한 읽으므로 defaultonly.name은 defaultname이 값이 된다.
- 활성화 되지 않은 application-dev.yml 파일의 프로퍼티들은 읽지 않는다.
간단한 ApplicationRunner를 작성하여 프로퍼티 값을 콘솔에 찍어본다.
@Component
public class Sample implements ApplicationRunner {
@Autowired
Environment env;
@Override
public void run(ApplicationArguments args) throws Exception {
System.out.println("=====================================================");
System.out.println("spring.profiles.active : " + args.getOptionValues("spring.profiles.active"));
System.out.println("Enviroment's Active Profile : " + Arrays.toString(env.getActiveProfiles()));
System.out.println("defaultonly.name : " + env.getProperty("devonly.name"));
System.out.println("testonly.name : " + env.getProperty("testonly.name"));
System.out.println("devonly.name : " + env.getProperty("devonly.name"));
System.out.println("profile-common.name : " + env.getProperty("profile-common.name"));
System.out.println("=====================================================");
}
}
===================================================== spring.profiles.active : [test] Enviroment's Active Profile : [test] defaultonly.name : defualtname testonly.name : testname devonly.name : null profile-common.name : testnameCommon ===================================================== |
'개발 > Spring & Spring Boot' 카테고리의 다른 글
스프링부트 로깅(Springboot Logging) (0) | 2020.12.06 |
---|---|
스프링부트(SpringBoot) 테스트 (0) | 2020.12.06 |
SpringBoot 프로퍼티(외부설정) (0) | 2020.12.05 |
Springboot Property Binding(스프링부트 프로퍼티 바인딩) (0) | 2020.12.05 |
ApplicationRunner, CommandLineRunner (0) | 2020.12.02 |