WEB서버와 WAS서버(feat.webtob,jeus)

러브굿·2023년 9월 9일
0

개발서버 세팅 중 웹투비와 제우스를 마주하게 되었다.(이둘은 인프라쪽에서 다세팅해줌 연동은 개발자몫)

web서버와 was서버로 분리하여 관리하는걸 보니 순간 현기증이나 이 글을 포스트하게 되었다.

어렴풋 알고 있던 개념이어서 찾아보니 잘못 이해한부분이 있길래 확실하게 정리할겸 적어본다.(참고로 난 아파치톰캣만써봣다 ㅋㅋ)


WEB Server와 WAS (Web Application Server)

간단하게는 web은 정적인걸 처리하고

was는 동적인걸 처리한다고 보면 된다.

이건 내 정리고 상세히 정리된 다른 레퍼런스 글을 보자 ㅎ

Web Server의 개념

소프트웨어와 하드웨어로 구분된다.
1) 하드웨어
Web 서버가 설치되어 있는 컴퓨터
2) 소프트웨어
웹 브라우저 클라이언트로부터 HTTP 요청을 받아 정적인 컨텐츠(.html .jpeg .css 등)를 제공하는 컴퓨터 프로그램

Web Server의 기능

HTTP 프로토콜을 기반으로 하여 클라이언트(웹 브라우저 또는 웹 크롤러)의 요청을 서비스 하는 기능을 담당한다.
요청에 따라 아래의 두 가지 기능 중 적절하게 선택하여 수행한다.
기능 1)
정적인 컨텐츠 제공
WAS를 거치지 않고 바로 자원을 제공한다.
기능 2)
동적인 컨텐츠 제공을 위한 요청 전달
클라이언트의 요청(Request)을 WAS에 보내고, WAS가 처리한 결과를 클라이언트에게 전달(응답, Response)한다.
클라이언트는 일반적으로 웹 브라우저를 의미한다.

Web Server의 예

Ex) Apache Server, Nginx, IIS(Windows 전용 Web 서버) 등

WAS의 개념

DB 조회나 다양한 로직 처리를 요구하는 동적인 컨텐츠를 제공하기 위해 만들어진 Application Server
HTTP를 통해 컴퓨터나 장치에 애플리케이션을 수행해주는 미들웨어(소프트웨어 엔진)이다.
“웹 컨테이너(Web Container)” 혹은 “서블릿 컨테이너(Servlet Container)”라고도 불린다.
Container란 JSP, Servlet을 실행시킬 수 있는 소프트웨어를 말한다.
즉, WAS는 JSP, Servlet 구동 환경을 제공한다.

WAS의 역할

WAS = Web Server + Web Container
Web Server 기능들을 구조적으로 분리하여 처리하고자하는 목적으로 제시되었다.
분산 트랜잭션, 보안, 메시징, 쓰레드 처리 등의 기능을 처리하는 분산 환경에서 사용된다.
주로 DB 서버와 같이 수행된다.
현재는 WAS가 가지고 있는 Web Server도 정적인 컨텐츠를 처리하는 데 있어서 성능상 큰 차이가 없다.

WAS의 주요 기능

프로그램 실행 환경과 DB 접속 기능 제공
여러 개의 트랜잭션(논리적인 작업 단위) 관리 기능
업무를 처리하는 비즈니스 로직 수행

WAS의 예

Ex) Tomcat, JBoss, Jeus, Web Sphere 등


Web Service Architecture

웹서비스를 구성시 다양한 구조로 갖추고 있지만 내가 해본것만 알아보자 나머진모른다.

Client -> WAS & Web Server -> DB : 모든 컨텐츠를 한고에 집중시켜, 웹서버와 WAS의 역할을 동시에 수행, 스위치를 통한 로드 밸런싱, 사용자가 적을 경우 효율적

Client -> Web Server -> WAS -> DB : 웹서버와 WAS의 기능적 분류를 통해 효과적인 분산을 유도, 정적인 데이터는 웹서버에서 처리, 동적인 데이터는 WAS가 처리

첫번째 구조가 아파치톰캣일것으로 추정(?)되며, 두번째 구조가 웹서버와 와스서버를 분리하여 분산처리하는 구조다.

WAS와 WebServer를 분리하는 이유는
1) 기능을 분리하여 서버의 부하방지
2) 물리적으로 분리하여 보안강화
3) 여러대의 WAS를 연결 가능(로드밸런싱의 역할 및 fail over, fail back 처리에 유리)
4) 여러 웹어플리케이션을 서비스 가능(java서버, c#서버, php서버 등 하나의 웹서비스를 통해 서비스 가능)

등이 있당. 내가 생각하기엔 첫번째 이유 서버부하방지가 젤 큰이유인듯


이전 프로젝트를 수행하며 배포관련해서 공부를 했는데, 그때 본 블로그(어딘지모름)에서 was는 web서버의 발전된 형태이다? 라고 설명해서(사실 내가 잘못이해하고 그렇게 해석했는지도모른다.) 여태 걍 그렇게 알고 있었다. 아마 톰캣에서 아파치 기능을 일부 제공하는것을 보고 그렇게 포스팅한거같다.

신나게 쓰다보니 웹투비와 제우스 얘기는 못했는데 걍담에 알아보자 ㅎㅎ


참고
https://gmlwjd9405.github.io/2018/10/27/webserver-vs-was.html
https://helloworld-88.tistory.com/71
https://bhjo0930.tistory.com/entry/Jeus-%EC%99%80-Webtob-%EC%86%8C%EA%B0%9C

profile
마라토너형 개발자

0개의 댓글