inflearn logo
강의

Course

Instructor

Real-world! Spring Boot and JPA Utilization 1 - Web Application Development

H2 Database Installation

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

100

rkawlrgke3kr9957

3 asked

0

[질문 내용]

h2 DB 연결할 때 처음 입력하는 url

jdbc:h2:~/jpashop과 이후 db 파일 생성후 입력하는 url인
jdbc:h2:tcp://localhost/~/jpashop의 차이가 무엇이며 왜 이후에는 이렇게 변경해서 연결하는 건가요?

java spring 웹앱 spring-boot jpa

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

주성님께서 H2 데이터베이스 연결 시 JDBC URL의 차이에 대해 질문하셨네요. 두 URL 형식과 그 차이점은 H2 데이터베이스의 사용 환경에 따라 다릅니다.

  1. jdbc:h2:~/jpashop:

    • 이 형식은 H2 데이터베이스를 내장 모드로 실행할 때 사용합니다. 데이터베이스 파일 jpashop.mv.db가 사용자 홈 디렉토리에 생성 및 저장되며, 애플리케이션이 시작될 때 해당 파일을 이용해 데이터베이스에 연결합니다.
    • 내장 모드는 보통 개발 및 테스트 환경에서 단순하고 빠르게 데이터베이스 작업을 수행할 때 유용합니다.
  2. jdbc:h2:tcp://localhost/~/jpashop:

    • 이 형식은 H2 데이터베이스를 서버 모드로 실행할 때 사용합니다. 여기서 localhost는 데이터베이스 서버의 주소를 가리킨습니다. 이렇게 설정하면 여러 애플리케이션이 동시에 같은 데이터베이스에 접속할 수 있습니다.
    • TCP 연결은 테스트나 개발 환경에서 실제 배포 환경과 유사한 조건을 만들기 위해 유용할 수 있습니다. 특히, 여러 개발자가 동일한 데이터베이스에 접근해야 하거나, 분산 애플리케이션에서 데이터베이스를 공유해야 할 때 적합합니다.

이러한 설정의 차이는 데이터베이스 접근 방식의 변화와 관계가 있습니다. 내장 모드는 간편하고 가볍지만, 외부 접근이 필요할 경우 서버 모드로 설정하여 여러 사용자 및 애플리케이션이 네트워크를 통해 접근할 수 있도록 합니다.

관련하여 더 많은 정보를 제공하는 기존 답변 게시물을 찾아보았습니다:

추가적으로 궁금한 사항이 있으시면 언제든지 질문해 주시길 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

sdk 설정 오류

0

43

2

오탈자 - @Transactional

0

50

1

src/test/resources 테스트 경로 문제

0

49

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

62

1

MemberRepositoryTest 실행오류

0

73

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

181

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

135

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

50

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

71

1

기본 생성자

0

59

1

멤버서비스테스트 부분에서 막힙니다.

0

163

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

115

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

117

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

108

1

24분 27초 연관관계 편의 메서드 위치

0

112

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

106

2

빌드 툴, Gradle

0

57

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

73

2

Repository에서 EntityManager 주입 방식 차이

0

87

1

롬복과 사용자 정의 setter 메서드

0

70

1

주문 목록 조회 fetch join 질문드립니다

0

79

1

dirty checking 질문드립니다.

0

78

1

동시성 관련 질문입니다

0

70

1

CASCADE 질문드립니다.

0

58

1