Web Server vs WAS

배세훈·2022년 9월 5일
0

1. Web Server(웹서버)란?

  • 웹 브라우저와 같은 클라이언트로부터 HTTP 요청을 받아서, HTML 문서나 정적인 오브젝트(이미지 파일 등)를 전송해주는 소프트웨어이다.
    즉, 쉽게 말해 웹 페이지를 클라이언트로 전달하는 것이다.

  • 대표적인 웹 서버는 Apache, IIS, Nginx, GWS 등이 있다.

2. Web Application Server(WAS)란?

  • 웹 애플리케이션과 서버 환경을 만들어 동작시키는 기능을 제공하는 소프트웨어 프레임워크이다.
    인터넷상에서 HTTP를 통해 사용자 컴퓨터나 장치에 애플리케이션을 수행해 주는 미들웨어(소프트웨어 엔진)로 볼 수 있다. WAS는 동적 서버 콘텐츠를 수행하는 것으로 일반적인 웹 서버와 구별이 되며, 주로 데이터베이스 서버와 같이 수행이 된다.

그리고 아래와 같은 기능을 제공한다.

  • 프로그램 실행 환경과 데이터베이스 접속 기능을 제공한다.
  • 여러 개의 트랜잭션을 관리한다.
  • 업무를 처리하는 비즈니스 로직을 수행한다.
  • 대표적인 WAS는 Tomcat, uWsgi, WebLogic, Jboss, Jeus가 있다.

WAS의 종류와 특징

Tomcat 기능
  • Jsp/Servlet Container중 하나로 사용자에게 JSP요청을 받으면 서블릿으로 바꾸어 실행
  • Web Server에서 요청한 동적 페이지를 읽어 프로그램을 실행
  • 그 결과를 다시 HTML로 재구성하여 Web Server에게 전달
Tomcat 특징
  • Servlet Container를 지원함
  • 플랫폼에 제약이 없음(Windows, Linux, Unix)

Servlet(서블릿) 이란?

개념
  • 클라이언트의 요청을 처리하고 그 결과를 반환하는 Servlet 클래스의 구현 규칙을 지킨 자바 웹 프로그래밍 기술
  • 자바를 사용하여 웹을 만들기 위해 필요한 기술
  • 클라이언트가 어떠한 요청을 하면 그에 대한 결과를 다시 전송 해주는 역할을 하는 자바 프로그램
특징
  • 클라이언트의 요청에 대해 동적으로 작동하는 웹 어플리케이션 컴포넌트
  • html을 사용하여 요청에 응답한다.
  • Java Thread를 이용하여 동작한다.
  • MVC 패턴에서 Controller로 이용된다.
  • HTTP 프로토콜 서비스를 지원하는 javax.servlet.http.HttpServlet 클래스를 상속받는다.

  1. 사용자(클라이언트)가 URL을 입력하면 HTTP Request가 Servlet Container로 전송한다.
  2. 요청을 전송받은 ServletContainer는 HttpServletRequest, HttpServletResponse 객체를 생성한다.
  3. web.xml을 기반으로 사용자가 요청한 URL이 어느 서블릿에 대한 요청인지 찾는다.
  4. 해당 서블릿에서 service메소드를 호출한 후 클라이언트의 GET, POST 여부에 따라 doGet()또는 doPost()를 호출한다.
  5. doGet() or doPost() 메소드는 동적 페이지를 생성한 후 HttpServletResponse 객체에 응답을 보낸다.
  6. 응답이 끝나면 HttpServletRequest, HttpServletResponse 두 객체를 소멸시킨다.
Servlet Container(서블릿 컨테이너)란?
  • 서블릿을 관리해주는 컨테이너
  • 서버에 서블릿을 만들었다고 해서 스스로 작동하는 것이 아니라 서블릿을 관리해주는 것이 필요한데 그 역할을 하는 것이 바로 서블릿 컨테이너다.
  • 서블릿은 실제 행동을 수행하고, 서블릿 컨테이너는 클라이언트의 요청(Request)을 받아주고 응답(Response)할 수 있게 웹서버와 소켓으로 통신하며 대표적인 예로 톰캣(Tomcat)이 있다.
  • 톰캣은 실제로 웹 서버와 통신하며 JSP와 Servlet이 작동하는 환경을 제공해준다.
JSP(Java Server Page)
  • Java 코드가 들어가 있는 HTML 코드
  • 서블릿은 자바 소스코드 속에 HTML 코드가 들어가 있는 형태인데 JSP는 이와 반대로 HTML 소스코드 속에 자바소스코드가 들어가는 구조를 갖는 웹 어플리케이션 프로그래밍 기술이다.
  • JSP는 WAS(Web Application Server)에 의하여 서블릿 클래스로 변환되어 사용된다.

  1. 웹서버가 사용자로부터 서블릿에 대한 요청을 받으면 서블릿 컨테이너에 그 요청을 넘긴다.
  2. 요청을 받은 컨테이너는 HttpRequest와 HttpResponse 객체를 만들어 이들을 통해 서블릿 doPost()나 doGet() 메소드 중 하나를 호출한다.
  3. 만약 서블릿만 사용하여 사용자가 요청한 웹 페이지를 보여주려면 out 객체의 println 메소드를 사용하여 HTML 문서를 작성해야 하는데 이는 추가/수정을 어렵게 하고 가독성도 떨어지기 때문에 JSP를 사용하여 비즈니스 로직과 프레젠테이션 로직을 분리한다.
  4. 여기서 서블릿은 데이터의 입력 수정 등에 대한 제어를 JSP에게 넘겨서 프레젠테이션 로직을 수행한 후 컨테이너에게 Response를 전달한다.
  5. 이렇게 만들어진 결과물은 사용자가 해당 페이지를 요청하면 컴파일이 되어 자바파일을 통해 .class 파일이 만들어지고 두 로직이 결합되어 클래스화 되는 것을 확인할 수 있다.
    즉, out 객체의 println 메소드를 사용해서 구현해야 하는 번거로움을 JSP가 대신 수행한다.

3. Web Application(웹 애플리케이션)란?

  • 웹 애플리케이션은 DB를 질의하고 데이터를 가공하여 제공하는 역할을 하며, 비즈니스로직이 웹 애플리케이션에서 구현이 된다.
  • 대표적인 웹 어플리케이션으로는 Spring, AS.NET, Django, Flask, PHP, JSP, ASP 등이 있다.

클라이언트가 웹 서버에 HTTP 요청을 보내게 되면 정적인 데이터일 경우 즉시 응답을 하지만, 동적 데이터일 경우 WAS에 요청을 전달한다. WAS는 웹 애플리케이션이 알 수 있는 형태로 변환하여 넘기고, 웹 애플리케이션에서 데이터를 처리하여 응답하게 된다.

profile
성장형 인간

0개의 댓글