강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

ajdsasld님의 프로필 이미지
ajdsasld

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

순수 JDBC

DB 서버에 “소켓”으로 접근한다는 게 어떤 의미일까요?

작성

·

120

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

순수 JDBC 강의까지 듣고 질문이 생겨 올립니다~

DB커넥션을 얻어 애플리케이션이 DB 서버에 "소켓"으로 연결된다고 하는데, 이 의미가 "네트워크 상에서 돌아가는 두 개의 프로그램 간 양방향 통신" 을 할 수 있게 소켓이라는 통(?)이 생겨서 연결된다고 보면 되려나요?

 

그리고, application.properties에 url에

jdbc:h2:tcp://localhost/~/test

이렇게 적으면 소켓 연결이라고 하셨는데 이 url에 대한 더 자세한 이해를 하고 싶은데 이 url이 정확히 어떤 의미일까요? tcp는 OSI 7계층에서 어렴풋이 들어온 용어 같습니다.

 

 

 

 

 

 

답변 1

1

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

소켓을 통한 DB 접근에 대한 질문에 대해 답변드리겠습니다. 소켓은 네트워크 상에서 통신을 하기 위한 종착지로 볼 수 있습니다. 쉽게 이야기하자면, 두 프로그램이 서로 데이터를 주고받기 위해 사용하는 통로입니다. DB 서버와 애플리케이션 간에 소켓을 이용해, 애플리케이션이 DB에 쿼리를 요청하고 결과를 받아오는 과정이 진행됩니다.

소켓 통신의 의미

소켓 통신은 네트워크에서 두 데이터가 오가며 양방향적으로 통신하는 것을 가능하게 합니다. 즉, 하나는 데이터를 보내고 다른 쪽에서는 그 데이터를 받는 형태가 됩니다. 이 과정에서 TCP (Transmission Control Protocol)라는 프로토콜이 데이터 전송의 신뢰성을 보장해줍니다.

JDBC URL 구성 요소

jdbc:h2:tcp://localhost/~/test URL은 몇 가지 요소로 구성되어 있습니다:

  • jdbc: Java Database Connectivity의 약자로, Java에서 데이터베이스와 연결하기 위해 사용하는 API를 의미합니다.
  • h2: 사용하고 있는 데이터베이스의 종류를 나타냅니다. H2는 내장형 데이터베이스로 널리 사용됩니다.
  • tcp: 데이터 전송에 사용될 프로토콜을 지정합니다. TCP/IP 프로토콜을 통해 네트워크 상에서 DB 서버와 연결됨을 나타냅니다.
  • localhost: 데이터베이스 서버가 실행 중인 호스트를 의미합니다. 여기서는 로컬 컴퓨터에서 서버가 실행되고 있음을 나타냅니다.
  • ~/test: 사용자 홈 디렉토리 내에 ‘test’라는 이름으로 데이터베이스 파일을 저장할 위치를 지정합니다.

자세한 URL 구조에 대해 설명한 자료는 다음 링크에도 나와 있습니다. 참고하시면 도움이 되실 것입니다:
- TCP 통신으로 연결하는 이유가 좀 더 궁금합니다!

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

ajdsasld님의 프로필 이미지
ajdsasld

작성한 질문수

질문하기