작성
·
292
·
수정됨
0
안녕하세요.
강의 내용과 조금 별개의 질문일 수 있는데 마땅히 물어볼 곳이 없어 질문드리게 되었습니다.
@Transactional(read-only) 로 설정했을 때, replication db 에서 조회하도록 Master, Replica 데이터 소스를 구성해보려고 하는데요,
Master 와 Replica 각각의 데이터소스와 AbstractRoutingDataSource
를 상속받는 routingDataSource 를 빈으로 등록 후,
EntityManagerFactory
도 빈으로 등록했습니다.
@Bean
public EntityManagerFactory entityManagerFactory(DataSource dataSource) {
LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
factory.setPackagesToScan("com.example.domain");
factory.setDataSource(dataSource);
HibernateJpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter();
factory.setJpaVendorAdapter(jpaVendorAdapter);
factory.afterPropertiesSet();
return factory.getObject();
}
이렇게 모두 설정하면 동작은 잘 되는데 application.yml 에 설정한 auto-ddl 이나 show_sql, form_sql 과 같은 프로퍼티 설정을 읽어오지 못하더라구요.
그래서 아래와 같이 HibernateJpaVendorAdapter 에 직접 설정을 추가해줘야지 동작했습니다.
HibernateJpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter();
jpaVendorAdapter.setGenerateDdl(true);
jpaVendorAdapter.setShowSql(true);
그런데 이렇게 직접적으로 설정값을 넣어서 구성하면 profile 에 따라 설정 값 적용을 분리하지 못하게되는데,
그럼 아래와 같이 Properties 를 직접 가져와서 설정 값에 넣어줘야하는걸까요? 이러한 방식이 맞는지 의문이 들어서 질문하게 되었습니다.
HibernateJpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter(); jpaVendorAdapter.setGenerateDdl(jpaProperties.isGenerateDdl());
jpaVendorAdapter.setShowSql(jpaProperties.isShowSql());
factory.setJpaVendorAdapter(jpaVendorAdapter);
그리고 구글링 했을 때 블로그 예제들은 현업에서 정말 사용하는 구성인지 Master, replica 를 설정하는데 참고할만한 좋은 레퍼런스 있으면 추천 부탁드립니다.
답변 1
0
안녕하세요, 인프런 AI 인턴이에요.
EntityManagerFactory 빈 등록과 관련해 질문이 있으신 것 같아 답변드릴게요.
EntityManagerFactory를 설정할 때 프로퍼티 설정을 읽어오지 못하는 문제가 발생하는 것 같네요. 이런 경우에는 HibernateJpaVendorAdapter에 직접 프로퍼티를 추가해야 합니다.
아래와 같이 프로퍼티를 추가해주시면 됩니다.
HibernateJpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter();
// 프로퍼티 추가
jpaVendorAdapter.setShowSql(true);
jpaVendorAdapter.setGenerateDdl(true);
// ...
factory.setJpaVendorAdapter(jpaVendorAdapter);
이렇게 설정을 추가하시면 application.yml의 프로퍼티 설정을 읽어올 수 있을 거예요.
추가로, EntityManagerFactory 설정은 어플리케이션의 전체적인 데이터베이스 연결 설정과 관련이 있으므로, 별도의 인프런 강의를 참고하시면 좋을 것 같습니다.
다른 궁금한 점이 있으시면 언제든지 물어보세요. 좋은 결과가 있길 바라요!