데이터베이스 서버

유석현(SeokHyun Yu)·2022년 8월 5일
0

SQL

목록 보기
3/45
post-thumbnail

서론

많은 RDBMS가 클라이언트/서버 모델을 채택해 가동 중이다.

특히 웹 시스템과 연동하는 RDBMS라면, 접속자 수가 수백 명에 달하는 전용 데이터베이스 서버를 운용하는 일도 드물지 않다.

여기서는 데이터베이스를 네트워크로 연결된 서버라는 관점에서 바라보며 이야기를 진행해 나갈 것이다.

RDBMS는 복수의 클라이언트가 보내오는 요청에 응답할 수 있도록 클라이언트/서버 모델로 동작한다.

클라이언트는 서버에 접속 요청이나 SQL 명령 실행요청을 보낼 수 있다.

서버는 이를 처리하고 클라이언트에 그 결과를 반환한다.

일반적으로 RDBMS는 네트워크 상에 하나의 서버를 두고 독점해 사용한다.


1. 클라이언트/서버 모델

클라이언트/서버 모델이란 사용자 조작에 따라 요청을 전달하는 '클라이언트'와 해당 요청을 받아 처리하는 '서버'로 소프트웨어를 나누고, 복수의 컴퓨터 상에서 하나의 모델을 구현하는 시스템을 말한다.

이 모델을 웹 시스템에서 특히 많이 사용하는데, 웹 시스템이란 브라우저웹 서버로 구성되는 클라이언트/서버 모델의 시스템을 말한다.

웹 시스템에서 클라이언트 기능을 하는 브라우저는 사용자가 지정한 URL과 연결된 웹 서버에 요청을 보낸다.

요청 내용은 상황에 따라 미묘하게 달라지겠지만, 그 대부분은 '이 페이지를 열람하고 싶다'일 것이다.

이때 클라이언트가 보내는 요구사항을 웹 용어로는 '리퀘스트(Request)'라고 한다.

클라이언트의 요청을 받은 웹 서버에서는 그에 맞게 처리한다.

요청이 '이 페이지를 열람하고 싶다'이므로, 서버는 브라우저가 페이지를 표시할 수 있도록 HTML로 된 데이터를 클라이언트로 반환한다.

데이터는 네트워크를 통해서 전송된다.

한편 서버의 응답은 웹 용어로 '리스폰스(Response)'라고 한다.

페이지 내용을 전달받은 브라우저는 화면에 페이지 내용을 표시한다.

이것으로, 전형적인 클라이언트/서버 모델에서의 처리가 하나 종료되었다.

실제 웹에서는 요청과 응답이 되풀이되면서 웹페이지가 표시된다.


2. 웹 애플리케이션의 구조

웹 애플리케이션은 일반적으로 웹 서버데이터베이스 서버의 조합으로 구축된다.

앞서 설명한 것처럼 웹 시스템은 클라이언트/서버 모델로 구성되며 브라우저가 클라이언트 역할을, 아파치(Apache)나 IIS와 같은 웹 소프트웨어가 서버 역할을 한다.

클라이언트가 서버에게 요청하면 웹 서버는 클라이언트에게 응답한다.

웹 사이트가 정적인 HTML만으로 구성되어 있다면 웹 서버만으로도 시스템을 구축할 수 있을 것이다.

하지만 웹 애플리케이션이라 부를 정도의 규모라면 데이터베이스가 필요하다.

그렇다면 웹 서버와 데이터베이스를 어떻게 연결하는 것일까?

바로 PHP나 루비 등의 프로그래밍 언어로 만들어진 CGI 프로그램을 사용하는 것이다.

그렇게 데이터베이스 서버와 연결이 되면 필요한 SQL 명령을 전달하고, 실행 결과는 클라이언트로 되돌아간다.

이때 웹 서버의 CGI 프로그램이 데이터베이스의 클라이언트가 된다.

profile
Backend Engineer

0개의 댓글