Java & Spring

java 웹 서버 및 WAS 개념정리, 차이점

닥치고개돌 2021. 8. 16. 15:34
728x90

웹 서버(Web Server)

  • HTTP 기반으로 동작
  • 정적 리소스 제공, 기타 부가기능
  •  정적(파일) HTML, CSS, JS, 이미지, 영상
  • 예) NGINX, APACHE

 

웹 애플리케이션 서버(WAS - Web Application Server)

 

  • HTTP 기반으로 동작
  • 웹 서버 기능 포함+ (정적 리소스 제공 가능)
  • 프로그램 코드를 실행해서 애플리케이션 로직 수행
    - 동적 HTML, HTTP API(JSON)
    - 서블릿, JSP, 스프링 MVC
  • ) 톰캣(Tomcat) Jetty, Undertow

 

차이점

웹 서버는 정적 리소스(파일), WAS는 애플리케이션 로직

자바는 서블릿 컨테이너 기능을 제공하면 WAS

 

웹 시스템의 구성

WAS는 정적 리소스, 애플리케이션 로직 모두 제공 가능해서 WAS, DB 만으로 시스템 구성 가능하다.

하지만 WAS가 너무 많은 역할을 담당하면, 서버 과부하 우려가 있고 가장 비싼 애플리케이션 로직이 정적 리소스 때문에 수행이 어려울 수 있음

또한, WAS 장애시 오류 화면도 노출 불가능하다.

따라서 요즘은 정적 리소스는 웹 서버가 처리하고, 애플리케이션 로직같은 동적인 처리가 필요하면 웹서버가 WAS에 요청을 위임하여 WAS는 중요한 애플리케이션 로직 처리 전담하는 프로세스로 구성.

이렇게 구현하면 또다른 장점은 정적 리소스만 제공하는 웹 서버는 잘 죽지 않고 애플리케이션 로직이 동작하는 WAS 서버는 잘 죽음으로( 보통 잘못된 코딩으로 개발자의 실수) WAS, DB 장애시 WEB 서버가 오류 화면을 제공할 수 있다.

 

728x90

'Java & Spring' 카테고리의 다른 글

java ArrayList 정리  (0) 2021.08.21
java 서블릿 개념정리  (0) 2021.08.16
java int to char 형변환  (0) 2021.08.15
java Collection 프레임워크 정리  (0) 2021.08.11
java array관련 함수  (0) 2021.08.09