웹이라는 것은 http라는 것을 기반으로 통신을 한다.
클라이언트(웹 브라우저)에서 url을 치면 인터넷을 통해 서버에 접근하고 서버에서는 html을 만들어서 클라이언트에 넘겨준다.
그럼 웹 브라우저는 받은 html을 화면을 그린다.
클라이언트에서 서버로 데이터 전송할때, 서버에서 클라이언트로 데이터를 응답할 때 이 모든것은 HTTP를 기반으로 동작한다.
모든 형태의 데이터는 HTTP 프로토콜 기반으로 동작함
HTML, TEXT, IMAGE, 음성, 영상, 파일
JSON, XML(api), 거의 모든 형태의 데이터 전송 기능
웹 서버
- HTTP 기반으로 동작
- 정적 리소스 제공, 기타 부가기능
- 정적파일 HTML, CSS, JS 이미지, 영상
예) NGINX, APACHE
웹 애플리케이션 서버(WAS) - Web Application Server
- HTTP 기반으로 동작
- 웹 서버 기능을 대부분 포함한 동작 (정적 리소스 제공 가능)
- 가장 큰 차이점은 프로그램 코드를 실행해서 애플리케이션 로직 수행
- 동적HTML, HTTP API(JSON)
- 서블릿, JSP, 스프링 MVC
예) 톰캣(Tomcat), Jetty, Undertow
WAS의 특징
- 동적인 콘텐츠 제공: 사용자의 입력에 따라 결과가 바뀌는 HTML, JSON 등을 생성.
- 서블릿/JSP 실행 환경: Java 기반의 웹 애플리케이션(서블릿, JSP)을 실행.
- 비즈니스 로직 처리: 데이터베이스와 통신하거나 복잡한 계산을 처리하는 애플리케이션 로직을 수행.
차이점?
웹 서버는 정적 리소스 파일, WAS는 애플리케이션 로직
사실은 둘의 용어도 경계도 모호함
- 웹 서버도 프로그램을 실행하는 기능을 포함하기도 한다.
- 웹 애플리케이션 서버도 웹 서버의 기능을 제공한다.
자바는 서블릿 컨테이너 기능을 제공하면 WAS
- 서블릿 없이 자바코드를 실행하는 서버 프레임워크도 있음
WAS는 애플리케이션 코드를 실행하는데 더 특화되어 있다.
웹 시스템 구성 - WAS, DB
- WAS가 너무 많은 역할을 담당하여 서버 과부하가 우려 됨.
- 가장 비싼 애플리케이션 로직(비즈니스로직) 이 정적 리소스 떄문에 수행이 어려울 수 있음.
- WAS장애시 오류 화면도 노출 불가능
[웹 서버는 필요하면 WAS를 호출]
정적 리소스는 웹 서버가 처리를 하게 함
웹 서버는 애플리케이션 로직같은 동적인 처리가 필요하면 WAS에 요청을 위임
WAS는 중요한 애플리케이션 로직 처리 전담
[효율적인 리소스 관리]
정적 리소스가 많이 사용되면 web서버 증설
애플리케이션 리소스가 많이 사용되면 was증설
[기본적인 기반?]
- 정적 리소스만 제공하는 웹 서버는 잘 죽지 않음
(단순히 파일만 읽어서 클라이언트에 제공하면 끝!)
- 애플리케이션 로직이 동작하는 WAS 서버는 잘 죽음
(여러가지 이유에서 잘 다운됨)
- 그렇다 할지라도 WAS, DB장애시 WEB서버가 오류 화면 제공 기능함.
데이터만 제공하게 되면 웹 서버가 굳이 없어도 됨.
쉽게 말해, WAS는 "브라우저가 요청한 내용을 서버에서 처리하고 만들어서 보내주는 핵심 엔진"인 것! 😊
댓글