[Spring] Testing에서 메모리 DB(MMBB) 사용하기와 메모리 DB란

2023. 6. 21. 13:33· Java/Spring

프로젝트 개발 중에 테스팅을 운영 디비와 같은 걸로 할 경우 

더미 데이터가 추가되는 데 이를 방지하기 위해 스프링에서는 메모리 디비를 사용할 수 있게 해 줍니다.

 

※ 메모리 DB(In-Memory Database, Main Memory DBMS) : 비휘발성이 아닌 휘발성인 주 메모리에 데이터를 기록하는 방법으로 데이터 조회가 빠르다는 장점을 지니지만 휘발성이므로 전원이 꺼질 시 데이터가 삭제됨, 주로 임시 데이터나 로그인 세션에 이용

DBMS 제품군에서 옵션으로 제공하기도 함 MySQL/MariaDB에서는 MEMORY 엔진이 예시

 

스프링은 테스트 폴더 위치에 resources 폴더가 있으면 그 파일을 우선적으로 사용하게 되는 데(없으면 main 폴더)

이때 src/test/resources/application.yml의 내용을 아래와 같이 바꾸면 스프링에서 메모리 디비를 사용하게 됩니다.

spring:

logging.level:
  org.hibernate.SQL: debug
  org.hibernate.type: trace

더 극적으로는 내용을 아예 다 비워도 됩니다.

 

이러면 테스트 코드 실행 시 memory db를 사용하는 걸 로그로 확인이 가능함

023-06-21 13:22:17.535  INFO 47956 --- [           main] p6spy                                    : #1687321337535 | took 0ms | statement | connection 2| url jdbc:h2:mem:4bfbe2b9-b7f9-44f1-8c78-5ee64d78dcf3
drop table if exists category CASCADE 
drop table if exists category CASCADE ;
2023-06-21 13:22:17.535 DEBUG 47956 --- [           main] org.hibernate.SQL                        : drop table if exists category_item CASCADE 
2023-06-21 13:22:17.535  INFO 47956 --- [           main] p6spy                                    : #1687321337535 | took 0ms | statement | connection 2| url jdbc:h2:mem:4bfbe2b9-b7f9-44f1-8c78-5ee64d78dcf3
drop table if exists category_item CASCADE 
drop table if exists category_item CASCADE ;
2023-06-21 13:22:17.535 DEBUG 47956 --- [           main] org.hibernate.SQL                        : drop table if exists delivery CASCADE 
2023-06-21 13:22:17.535  INFO 47956 --- [           main] p6spy                                    : #1687321337535 | took 0ms | statement | connection 2| url jdbc:h2:mem:4bfbe2b9-b7f9-44f1-8c78-5ee64d78dcf3
drop table if exists delivery CASCADE 
drop table if exists delivery CASCADE ;
2023-06-21 13:22:17.535 DEBUG 47956 --- [           main] org.hibernate.SQL                        : drop table if exists item CASCADE 
2023-06-21 13:22:17.535  INFO 47956 --- [           main] p6spy                                    : #1687321337535 | took 0ms | statement | connection 2| url jdbc:h2:mem:4bfbe2b9-b7f9-44f1-8c78-5ee64d78dcf3
drop table if exists item CASCADE 
drop table if exists item CASCADE ;
2023-06-21 13:22:17.535 DEBUG 47956 --- [           main] org.hibernate.SQL                        : drop table if exists member CASCADE 
2023-06-21 13:22:17.535  INFO 47956 --- [           main] p6spy                                    : #1687321337535 | took 0ms | statement | connection 2| url jdbc:h2:mem:4bfbe2b9-b7f9-44f1-8c78-5ee64d78dcf3
drop table if exists member CASCADE 
drop table if exists member CASCADE ;
2023-06-21 13:22:17.535 DEBUG 47956 --- [           main] org.hibernate.SQL                        : drop table if exists order_item CASCADE 
2023-06-21 13:22:17.535  INFO 47956 --- [           main] p6spy                                    : #1687321337535 | took 0ms | statement | connection 2| url jdbc:h2:mem:4bfbe2b9-b7f9-44f1-8c78-5ee64d78dcf3

 

반응형

'Java > Spring' 카테고리의 다른 글

[H2] Database 생성 오류 Database "/Users/유저명/DB명" not found, either pre-create it or allow remote database creation (not recommended in secure environments)  (0) 2023.06.21
[Spring] ModelAndView 리턴 값 한글 깨짐  (1) 2022.05.18
'Java/Spring' 카테고리의 다른 글
  • [H2] Database 생성 오류 Database "/Users/유저명/DB명" not found, either pre-create it or allow remote database creation (not recommended in secure environments)
  • [Spring] ModelAndView 리턴 값 한글 깨짐
DSeung
DSeung
DSeung
Dev log
DSeung
  • 분류 전체보기 (193)
    • PHP (62)
      • Laravel (31)
      • Error (5)
      • Setting (11)
      • Modern PHP (15)
    • Go Lang (51)
      • Study (30)
      • Algorithm (17)
      • Setting (1)
      • Error (3)
    • Java (11)
      • Spring (3)
      • JSP (0)
      • Error (2)
      • Setting (2)
      • 단축키 (2)
    • JavaScript (6)
      • Modern JavaScript (4)
      • Node (1)
    • Android Kotlin (5)
      • Study (4)
      • Error (1)
    • 컴퓨팅 기술 (12)
      • 데이터베이스시스템 (4)
      • Docker (2)
      • 크롤링 & 스크래핑 (1)
      • API (1)
      • 클라우드 (1)
      • 네트워크 (1)
    • MySQL (7)
    • AWS (1)
    • Git (5)
      • GItLab (1)
      • GitHub (4)
    • 도메인 (2)
      • 안과 (2)
    • 자격증 (7)
      • SQLD (1)
      • 정보처리기사 (6)
    • Mac os (1)
    • 나머지 (13)
      • tistory (1)
      • 기타 (9)
      • 일기 (3)
    • 독서 (10)

인기 글

최근 글

블로그 메뉴

  • 홈
  • 태그
전체
오늘
어제
hELLO · Designed By 정상우.v4.2.0
DSeung
[Spring] Testing에서 메모리 DB(MMBB) 사용하기와 메모리 DB란
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.