본문 바로가기

Web Programming

Web Server vs WAS / Web Server와 WAS의 차이

 

정적 페이지 / 동적 페이지 개념

https://www.zesty.io/mindshare/marketing-technology/dynamic-vs-static-websites/

 

 

Static Page
Dynamic Page
파일 경로 이름을 받아 경로와 일치하는 file contents 반환
(항상, 모두에게, 어느 브라우저에서든 동일한 페이지)

Ex) image, html, css, javascript 등 컴퓨터 저장파일
네이버 메인화면 (로그인전)


인자의 내용에 맞게 동적인 contents를 반환
서버의 요청에 따라 실시간으로 구동

 Servlet: WAS 위에서 돌아가는 Java Program
개발자는 Servlet에 doGet()을 구현
Ex) 네이버 메인화면 (로그인후)

 

 

Web Server vs WAS

https://itsandtravels.blogspot.com/2018/12/web-server-wasweb-application-server.html

 

Web Server WAS(Web Application Server)

Web 서버가 설치되어 있는 컴퓨터 or 

웹 브라우저 클라이언트로부터 HTTP 요청을 받아 정적인 컨텐츠(.html .jpeg .css 등)를 제공하는 컴퓨터 프로그램을 의미
DB 조회나 다양한 로직 처리를 요구하는 동적인 컨텐츠를 제공하기 위해 만들어진 Application Server

HTTP를 통해 컴퓨터나 장치에 애플리케이션을 수행해주는 미들웨어(소프트웨어 엔진)
“웹 컨테이너(Web Container)” 혹은 “서블릿 컨테이너(Servlet Container)”라고도 불림

HTTP 프로토콜을 기반으로 클라이언트(웹 브라우저 또는 웹 크롤러)의 요청을 서비스 하는 기능 WAS = Web Server + Web Container
Web Server 기능들을 구조적으로 분리하여 처리하고자하는 목적으로 제시되었다.
분산 트랜잭션, 보안, 메시징, 쓰레드 처리 등의 기능을 처리하는 분산 환경에서 사용된다.
주로 DB 서버와 같이 수행된다.
현재는 WAS가 가지고 있는 Web Server도 정적인 컨텐츠를 처리하는 데 있어서 성능상 큰 차이가 없다.
정적인 컨텐츠 제공
WAS를 거치지 않고 바로 자원을 제공

동적인 컨텐츠 제공을 위한 요청 전달
클라이언트의 요청(Request)을 WAS에 보내고, WAS가 처리한 결과를 클라이언트에게 전달(응답, Response).


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

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


Ex) Tomcat, JBoss, Jeus, Web Sphere 등
Web Server를 통해 정적인 파일들을 Application Server까지 가지 않고 빠르게 처리
=> 기능 분배를 통한 서버 부담 최소화
 WAS를 통해 요청에 맞는 데이터를 DB에서 가져와서 비즈니스 로직에 맞게 동적 결과 제공

 

결론

Web Server와 WAS의 기능을 분리하여 서버 부하 방지

정적 컨텐츠 (모두에게 동일하게 보이는 컨텐츠)는 Web Server가, 

동적 컨텐츠 (사용자별 다르게 조회되는, 주로 DB 와 관련된 컨텐츠)는 Web Server가 처리

 

 

* web.xml 파일:

 

  - 배포서술자(DD, Development Descriptor) 
  - 해당 웹어플리케이션의 기본적인 설정을 위해 작성하는 파일
  - 해당 웹 어플리케이션 구동 서버가 start시 제일 먼저 읽히는 파일
  - 개발자가 web.xml 파일을 수정하지 않고도 개발 및 운영이 가능하나 규모가 커지고,
      다양한 API 사용시 직접 수정해야하는 경우가생김

 

 

* welcome-file:

url로 해당 어플리케이션 루트 요청시 제일 처음 보여지게 되는 메인 페이지
http:// 구동중인 서버의 ip주소: 포트번호/
=> IP주소: 127.0.0.1 == localhost로 바꿀 수 있음 
(윈도우에서 전역변수 지정되어있음)
=> 본인 포트번호: 8888(아까 지정한 포트번호)
=> 서버내 구동중인 context root지정:
 1_Servlethttp://localhost:8888/1_Servlet==> 이렇게 요청을 보내면 welcome파일을 보여줌
  단, welcome-file-list에 존재하는 파일명이 WebContent폴더 내에 위치해야함

 

 

 

References

 

https://www.zesty.io/mindshare/marketing-technology/dynamic-vs-static-websites/

 

Dynamic vs. Static Websites: What's the Diff?

Static sites deliver pages in the same way to all users, whereas dynamic sites have content that displays differently based on a user's settings or behaviors.

www.zesty.io

http://hyeonstorage.tistory.com/78

https://gmlwjd9405.github.io/2018/10/27/webserver-vs-was.html

 

[Web] Web Server와 WAS의 차이와 웹 서비스 구조 - Heee's Development Blog

Step by step goes a long way.

gmlwjd9405.github.io

https://itsandtravels.blogspot.com/2018/12/web-server-wasweb-application-server.html

 

WEB server, WAS(Web Application Server)란?

WEB server, WAS

itsandtravels.blogspot.com