웹 서버 (Web Server)
- http 기반으로 동작
- 정적 리소스 제공
- 정적(파일) HTML, CSS, JS, 이미지, 영상
- ex) NGINX, APACHE
웹 애플리케이션 서버 (WAS)
- http 기반으로 동작
- 웹 서버 기능 포함+ (정적 리소스 제공 가능)
- 프로그램 코드를 실행해서 애플리케이션 로직 수행
- 동적 HTML, HTTP API (JSON)
- 서블릿, JSP, 스프링 MVC
- ex) 톰캣(Tomcat) Jetty, Undertow
웹 시스템 구성 - web, was, DB
WAS, DB 만으로 웹 시스템을 구성할 수 있다. WAS는 정적 리소스, 애플리케이션 로직 모두 제공 가능하기 때문에...
그러나 WAS가 너무 많은 역할을 담당하여 서버 과부하가 우려되는 단점이 있고, WAS 장애시 오류 화면도 노출이 불가능하기 때문에 웹 서버도 함께 구성하는 것이 바람직하다.
정적 리소스는 웹 서버가 처리하고 동적인 처리가 필요하면 WAS에 요청을 위임한다.
WAS는 중요한 애플리케이션 로직 처리를 전담한다.
장점
- 효율적인 리소스 관리
- 정적 리소스가 많이 사용되면 Web 서버 증설
- 애플리케이션 리소스가 많이 사용되면 WAS 증설
- 정적 리소스만 제공하는 웹 서버는 잘 죽지 않는다.
- 애플리케이션 로직이 동작하는 WAS 서버는 잘 죽는다.
-> WAS, DB 장애시 WEB 서버가 오류 화면을 제공할 수 있다.