웹 서비스 구조

바퀴달린 개발자·2022년 5월 7일
0

바퀴달린 개발자

목록 보기
1/4

미들웨어(MiddleWare)란?

  • 양 쪽을 연결하여 데이터를 주고 받을 수 있도록 중간에세 매개 역할을 하는 소프트웨어
  • 비즈니스 로직은 미들웨어 서버에서 동작하도록 한다.
  • MOM, WAS 등이 있다.

Client - MiddleWare Server - DB Server

  1. client는 단순히 요청만 중앙에 있는 MiddelWare Server에게 보낸다.
  2. MiddelWare Server에서 대부분의 로직이 수행된다.
  3. 이 때, 데이터를 조작할 일이 있으면 DBMS에 부탁한다.
  4. 로직의 결과를 Client에게 전송한다.
  5. Client는 그 결과를 화면의 보여준다.

웹서비스 구조

  1. Client -> Web Server -> DB
  2. Client -> Web Application Server -> DB
  3. Client -> Web Server -> Web Application Server -> DB

GOAL
1. Web Server란?
2. WAS(Web Application Server)란?
3. Web 서비스 구조(Web Service Architecture)란?

Static Pages와 Dynamic Pages

Static Pages

  • Web Server는 파일 경로 이름을 받어 경로와 일치하는 file contents를 반환한다.
  • 항상 동일한 페이지를 반환 한다.
  • ex) image, html, css, javascript 파일과 같이 컴퓨터에 저장되어 있는 파일들

Dynamic Pages

  • 인자의 내용에 맞게 동적인 contents를 반환한다.
  • 즉, 웹 서버에 의해서 실행되는 프로그램을 통해서 만들어진 결과물
  • 개발자는 Servlet에 doGet()을 구현한다.
    *Servelt이란 WAS 위에서 돌아가는 Java Program

Web Server

  • 웹 브라우저 클라이언트로부터 HTTP 요청을 받아 정적인 컨텐츠(.html .jpeg .css 등)를 제공하는 컴퓨터 프로그램

  • HTTP 프로토콜을 기반으로 하여 클라이언트(웹 브라우저 또는 웹 크롤러)의 요청을 서비스하는 기능을 담당한다.

기능 1)

  • 정적인 컨텐츠 제공
  • WAS를 거치지 않고 바로 자원을 제공한다.

기능 2)

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

ex) Apache Server, Nginx

WAS (Web Application Server)

  • 동적인 컨텐츠를 제공하기 위해 만들어진 Application Server
  • 주로 DB 서버와 같이 수행되는데 클라이언트의 요청을 DB 서버와의 매개를 통해 비즈니스 로직 등을 처리하는 역할을 수행함.

Web Server + Web Container

  • Web Server
  • Web Container
    - JSP, Servlet 구동 환경을 제공한다.

ex) Tomcat, JBoss, Jeus, Wep Spehere

Web Server와 WAS를 구분하는 이유

  1. 기능을 분리하여 서버 부하 방지
  • 클라이언트는 html 문서를 먼저 받고 그에 맞게 필요한 이미지 파일들을 다시 서버로 요청하면 그때서야 이미지 파일을 받아온다. 이 때 웹서버를 통해 정적인 파일을 앞단에서 빠르게 보내줄 수 있다.
  • WAS는 DB 조회나 다양한 로직을 처리하느라 바쁘기 때문에 단순한 정적 컨텐츠는 web server에서 빠르게 클라이어느에 제공하는 것이 좋다.
  1. 물리적으로 분리하여 보안 강화
  • WAS에는 실제 Web Application이 실행되기 때문에 외부와 직접 연결이 되어 있다면 리소스들이 외부로 노출될 우려가 있다.
  1. 여러 대의 was를 연결 가능 -> 로드 밸런싱 가능!
  • WAS를 여러대 두고 Web Server에서 요청을 분산시켜 로드밸런싱 해준다. -> 하나의 WAS가 처리하는 요청의 양이 줄어들어 안정적인 서비스가 가능하다.
  • 여러 대의 WAS를 사용하면 하나의 WAS에서 장애가 생기더라도 해당 WAS를 사용 중지시키고 재시작함으로써 무중단 운여으 장애 극복(Failover) 등에 유리하다.

추가
=> 접근 허용 ip 관리, 2대 이상의 서버에서의 세션 관리 등도 웹서버에서 처리하면 효율적이다.
=> 웹서버를 was 앞에 두고 필요한 Was들을 웹서버에 플러그인 형태로 설정하면 더욱 효율적인 분산 처리가 가능하다.

Web Service Architecture

  1. 웹서버는 웹 브라우저 클라이언트로 부터 HTTP 요청을 받는다
  2. 웹 서버는 클라이언트의 요청(Request)를 WAS에 보낸다.
  3. WAS는 관련된 Servlet을 메모리에 올린다.
  4. WAS는 web.xml을 참조하여 해당 Servlet에 대한 Thread를 생성한다. (Thread Pool 이용)
  5. HttpServletRequest와 HttpServletResponse 객체를 생성하여 Servlet에 전달한다.
  6. doGet() 또는 doPost() 메서드는 인자에 맞게 생성된 적절한 동적 페이지를 Response 객체에 담아 WAS에 전달한다.
  7. WAS는 Response 객체를 HttpResponse형태로 바꾸어 Web Server에 전달한다.
  8. 생성된 Thread를 종료하고, HttpServletRequest와 HttpServletRespose 객체를 제거한다.

Servlet이란?

  • 자바를 사용하여 웹을 만들기 위해 필요한 기술
  • 클라이언트가 어떠한 요청을 하면 그에 대한 결과를 다시 전송해주는 역할을 하는 자바 프로그램
  • 웹 서버가 동적인 페이지를 제공할 수 잇도록 제공할 수 있도록 오와주는 애플리케이션이다.
  • MVC 패턴에서 Controller로 이용된다.

🐥 연관 개념

  • Web server 설정
  • WAS 설정
  • Servlet이란
  • HttpServletRequest/Response란?

참고
https://gmlwjd9405.github.io/2018/10/27/webserver-vs-was.html
https://mangkyu.tistory.com/14 (Servlet)

0개의 댓글