New

웹 서비스의 클라이언트-서버 구조

lshjju 2025. 8. 14. 14:34

웹 서비스의 클라이언트-서버 구조란?


웹 서비스는 크게 두 가지 역할, 즉 **'클라이언트(Client)'**와 **'서버(Server)'**가 서로 협력하여 동작하는 구조를 가지고 있습니다. 

이 두 역할은 마치 손님과 식당처럼 분리되어 있습니다.

출처-서브웨이

 



1. 클라이언트 (Client) - '주문하는 손님'



무엇인가요?: 

클라이언트는 사용자가 웹 서비스와 상호작용하는 부분입니다. 

주로 웹 브라우저(크롬, 엣지, 사파리 등)나 모바일 앱이 클라이언트 역할을 합니다.  



어떤 역할을 하나요?: 

사용자의 요청(정보 검색, 게시글 작성, 상품 구매 등)을 받아서 서버로 전달하고, 서버가 보낸 응답(웹 페이지, 데이터)을 사용자에게 보여주는 역할을 합니다.



비유:
'음식을 주문하는 손님': "메뉴판을 보여주세요!", "짜장면 하나 주세요!" 라고 요청하고, 요리된 음식을 받아먹는 역할을 합니다.


 

2. 서버 (Server) - '요리하는 주방장'



무엇인가요?: 

서버는 클라이언트의 요청을 받아서 처리하고 응답을 보내주는 부분입니다. 

웹 애플리케이션, 데이터베이스, 파일 등을 관리하는 컴퓨터와 소프트웨어의 조합입니다.   



어떤 역할을 하나요?: 

클라이언트로부터 요청을 받으면, 데이터를 처리하고, 필요한 경우 데이터베이스에서 정보를 가져오거나 저장하며, 결과를 가공하여 클라이언트에게 다시 보냅니다.



비유:
'음식을 요리하는 주방장': 손님의 주문(요청)을 받아서, 식재료를 사용하고, 레시피에 따라 요리(데이터 처리)를 한 후, 완성된 음식을 손님에게 제공합니다.



클라이언트-서버 구조의 동작 원리 (음식 주문 과정)


웹 서비스는 다음과 같은 단계로 클라이언트와 서버가 상호작용합니다.



요청 (Request) - '주문하기':

클라이언트(손님)가 특정 정보나 서비스(예: "네이버 웹페이지 보여줘!", "검색어 '리액트'로 검색해 줘!")를 서버(주방장)에게 요청합니다.


이 요청은 인터넷(네트워크)을 통해 서버로 전달됩니다. 



처리 (Process) - '요리하기':

서버(주방장)는 클라이언트의 요청을 받아서, 그에 맞는 작업을 수행합니다.


예를 들어, "리액트 검색" 요청을 받으면 서버는 데이터베이스에서 리액트 관련 정보를 찾고, 그 결과를 정리합니다.


응답 (Response) - '음식 내어주기':

서버(주방장)는 요청 처리가 완료되면, 그 결과(예: 웹 페이지 내용, 이미지, 동영상 등)를 클라이언트(손님)에게 응답으로 돌려보냅니다. 


이 응답 또한 인터넷(네트워크)을 통해 클라이언트로 전달됩니다.


표시 (Display) - '음식 맛보기':

클라이언트(손님)는 서버로부터 받은 응답을 해석하여 사용자에게 웹 페이지 형태로 보여줍니다.



왜 이렇게 복잡하게 나눌까요? (장점)



역할 분담: 

각자의 역할을 명확히 분담하여 효율적으로 서비스를 제공하고, 유지보수를 쉽게 만듭니다.



확장성: 

서버는 여러 클라이언트의 요청을 동시에 처리할 수 있고, 필요에 따라 서버 자원(CPU, 메모리)을 확장하여 더 많은 요청을 처리할 수 있습니다.



보안성: 

중요한 데이터베이스나 비즈니스 로직은 서버에만 존재하므로, 클라이언트 측에서 직접 접근할 수 없어 보안성이 높습니다.


결론


웹 서비스의 클라이언트-서버 구조는 사용자(클라이언트)가 요청을 보내면, 서비스 제공자(서버)가 이를 처리하여 응답하는 방식으로 인터넷의 모든 서비스가 동작하는 기본 원리입니다.

client-server.PNG
0.72MB

'New' 카테고리의 다른 글

localhost:8080  (2) 2025.08.14
IP 주소 (IP Address) / 포트 (Port)  (3) 2025.08.14
WAS - Web Application Server  (7) 2025.08.13
Web Framework  (3) 2025.08.13
github CDN json data raw file  (2) 2025.08.05