배포 환경에서 db 분리 질문
342
작성한 질문수 69
안녕하세요 영한님! 항상 강의 정말 잘 듣고 있습니다!
gradle build를 진행할 때 테스트 코드를 수행하는 걸로 알고 있습니다.
테스트 코드는 운영 db가 아닌 테스트용 db를 통해 수행하도록 하는게 맞을까요?
생각하고 있는 방법은
1. test/resources에 application.yml을 추가해서 테스트 코드는 인메모리 db (h2)를 통해 수행
2. ec2 안에 테스트용 mysql 컨테이너를 띄워두고 mysql을 통해 테스트 코드 수행이렇게 2가지 방식을 생각중인데 맞는 방법일까요??
답변 2
1
안녕하세요. 동민님, 공식 서포터즈 y2gcoder입니다. AI 답변에 더하여 답변 드립니다.
AI 답변 외에도 테스트용 DB를 도커 컨테이너로 띄워놓고 테스트하는 방법도 있으며 이를 더 편리하게 사용할 수 있게 도와주는 라이브러리(클릭) 등도 있으니 참고해보시면 좋을 것 같습니다!
감사합니다.
1
안녕하세요, 인프런 AI 인턴입니다.
동민님의 질문과 관련하여, 테스트 환경에서 DB를 분리하는 것에 대한 명확한 답변을 드릴 수 있을 것 같습니다.
첫 번째 방식인 인메모리 DB(H2) 를 사용하는 방식은 테스트 환경을 신속하게 구성할 수 있으며, 외부 의존성 없이 독립적으로 테스트를 실행할 수 있는 장점이 있습니다. 이러한 방식은 통합 테스트나 DAO 테스트 등을 진행할 때 매우 유용합니다.
두 번째 방식으로 EC2 안에 테스트용 MySQL 컨테이너를 띄워서 사용하는 방법 역시 고려할 수 있는 옵션입니다. 이 경우, 운영 환경과 더 유사한 환경에서 테스트를 할 수 있으나, 환경 구성이 좀 더 복잡해질 수 있고, 운영 DB와의 충돌을 방지하기 위해 주의해야 합니다.
이와 관련된 몇 가지 참고 자료를 제공해 드립니다:
테스트 환경에서 DB 분리 방법에 대한 고민 - 여기서는 테스트 환경에서의 DB 분리 방법에 대해 다양한 접근 방식을 고려하고 있으며, 각 방식의 장단점에 대해 설명하고 있습니다.
안녕하세요 메모리 테스트 db관련 질문입니다. - 테스트 환경에서 인메모리 DB를 사용할 때 생기는 궁금증을 해결해 줍니다.
각 방식에는 자신만의 장단점이 있기 때문에, 프로젝트의 요구사항 및 테스트의 목적에 따라 적합한 방식을 선택하는 것이 중요합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
sdk 설정 오류
0
53
2
오탈자 - @Transactional
0
56
1
src/test/resources 테스트 경로 문제
0
50
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
64
1
MemberRepositoryTest 실행오류
0
81
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
183
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
142
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
51
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
71
1
기본 생성자
0
60
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
103
1
멤버서비스테스트 부분에서 막힙니다.
0
165
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
116
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
120
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
114
1
24분 27초 연관관계 편의 메서드 위치
0
113
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
109
2
빌드 툴, Gradle
0
59
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
77
2
Repository에서 EntityManager 주입 방식 차이
0
90
1
롬복과 사용자 정의 setter 메서드
0
72
1
주문 목록 조회 fetch join 질문드립니다
0
82
1
dirty checking 질문드립니다.
0
83
1
동시성 관련 질문입니다
0
75
1





