6. Environment 1부 프로파일(Profile)
ApplicationContext는 EnvironmentCapable이라는 인터페이스를 상속받는다.
getEnvironment() 함수로 컴포넌트와 연관된 Environment 를 리턴한다.
Profile 이란 ?
- Bean들의 그룹
- Environment 의 역할은 Active할 Profile을 확인하고 설정한다.
Profile UseCase
- Test 환경에서 A라는 Bean을 사용하지만, Release 환경에서는 B 라는 Bean을 사용하고 싶을 때
- 사용 환경에 따라 Bean의 등록 및 사용 유무를 설정하고 싶을 때
Profile 정의하기
- Class에 정의
- @Configuration @Profile(”test”)
- @Component @Profile(”test”)
- 메소드에 정의
Profile 설정하기
Profile 표현식
Profile 표현식에 논리연산자를 사용할 수 있다.
ex ) @Profile(”!prod”) → prod 환경이 아닐 때 bean 사용
7. Environment 2부. 프로퍼티(Property)
Property 란?
- 개발 환경 구성에 필요한 설정값들, 다양한 방법으로 정의가 가능
- Environment 의 역할은 Property 소스 설정 및 Property 값 가져오기
Property의 우선순위
- StandardServletEnvironment의 우선순위
- ServeltConfig의 매개변수
- ServletContext의 매개변수
- JNDI (java.comp/env)
- JVM 시스템 Property(-Dkey=”value”)
- JVM 시스템 환경변수 (운영체제 환경변수)
@PropertySource
- Environment 를 통해 Property를 추가하는 방법이다.
- 사용 방법 :
@PropertySource("classpath:/com/jhj/app.properties")
- 소스코드 상 Config 파일에 애노테이션을 추가
- property 파일에 기재된 설정 값들은
@Value(${...})
형태로 주입받아 사용이 가능하다. → BeanPostProcessor에 의해서 처리되기 때문에BeanPostProcessor나 BeanFactoryPostProcessor 내에서는 사용할 수 없다.
8. MessageSource
국제화 기능(i18n) 기능을 제공하는 인터페이스 → 메세지를 다국화 하는 기능
- ApplicationContext는 MessageSource를 상속받는다.
- SpringBoot를 사용하면, 다른 설정 없이 messages.properties 파일로 메세지 다국화 기능 사용이 가능하다.
- messages.properties
- messages_ko_KR.preporties
- messages_en_US.properties
- Local.getDefault() : 운영체제의 기본으로 설정되니 국가의 값을 가져옴 (ref. ttps://docs.oracle.com/javase/7/docs/api/java/util/Locale.html#getDefault)
messageSource.getMessage("greeting", new String[]{"jhjhj"}, Locale.getDefault());
messageSource.getMessage("greeting", new String[]{"jhjhj"}, Locale.KOREA);
messageSource.getMessage("greeting", new String[]{"jhjhj"}, Locale.US);
Reloading 기능이 있는 메세지 소스
캐시 설정을 이용해서 메세지 reload가 가능하다.
@Bean
public MessageSource messageSource(){
var messageSource = new ReloadableResourceBundleMessageSource();
messageSource.setBasename("classpath:/messages_ko_KR");
messageSource.setDefaultEncoding("UTF-8");
messageSource.setCacheSeconds(3);
return messageSource;
}
9. ApplicationEventPublisher
ApplicationContext extend ApplicationEventPublisher
이벤트 프로그래임에 필요한 Interface를 제공한다. Observer Pattern (옵저버 패턴) 의 구현체이다.
Event 만들기
- 이벤트로 만들 클래스는 ApplicationEvnet 클래스( `org.springframework.context.ApplicationEvent`)를 상속받는다.
- Spring 4.2 버전 이후부터 이 클래스를 상속받지 않아도 이벤트로 사용할 수 있다. → 이벤트 핸들러로 사용될 클래스를 빈으로 등록하고 핸들러 메소드에
@EventListener
애노테이션을 붙이면 된다.
Event 발생 시키는 방법
ApplicationEventPublisher.publishEvent(new Evnet);
Event 처리하는 방법
- ApplicationListener<이벤트> 로 구현한 클래스를 생성 후, Bean으로 등록한다.
- Spring 4.2 버전부터는
@EventListener
애노테이션을 메소드에 사용해서 이벤트 리스너 메소드로 사용할 수 있다.
- 기본적으로 동기 (synchronized) 이다. 비동기로 사용하고 싶다면
@Async
애노테이션을 클래스에 사용하면 된다.
- 이벤트 발생 순서를 정하고 싶다면, 이벤트 리스너에
@Order
애노테이션을 사용하고, 우선순위에 따라 옵션값을 설정하면 된다.
스프링이 기본으로 제공하는 Event
10. ResourceLoader
Resource를 읽어오는 기능을 제공하는 Interface 이다.
ApplicationContext가 ResourceLoader를 상속받는다.
Resource 읽어오는 방법
- 파일 시스템에서 읽어오기
- classpath에서 읽어오기 (/target/classes가 root)
- URL 로 읽어오기
- 상대/절대 경로로 읽어오기
→ 자세한 방법은 공식 레퍼런스 참조
출처 : [인프런 강의] 백기선 - 스프링 프레임워크 핵심기술