ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • Web 기본 동작 방식(in spring)
    Spring 2021. 11. 22. 17:21

    웹 서버, WAS(Web Application Server)

    • 웹 서버, WAS 모두 HTTP 기반으로 동작
    • 웹 서버는 정적 리소스(파일)
    • WAS는 서버 기능 + 정적 리소스
      • 동적 HTML, HTTP API(JSON), 서블릿, JSP, 스프링MVC
      • 애플리케이션 코드를 실행하는데 더 특화

    Servlet

    • HTTP 요청 및 응답 정보를 평리하게 사용하거나 제공할 수 있다. 즉, 개발자는 HTTP 스펙을 매우 편리하게 사용가능하다.

    서블릿 컨테이너

    • 톰캣처럼 서블릿을 지원하는 WAS를 서블릿 컨테이너라고 함
    • 서블릿 생성, 호출, 관리해줌
    • 서블릿 객체는 싱글톤으로 관리
      • 요청마다 새로운 객체 생성은 비효율적.
      • 주의) 공유 변수 사용 주의(지역변수, 파라미터, ThreadLocal 등을 사용해야함)
        • 멀티 쓰레드 처리 지원(중요)🎯

    쓰레드

    • 애플리케이션 코드를 하나하나 순차적으로 실행하는것
    • 동시 처리가 필요하면 쓰레드를 추가

    멀티 쓰레드

    • WAS에서 지원해준다(핵심, 멀티쓰레드 관련 코드 작성 x). 동시 요청 처리 가능 🎯
      • 주의) 멀티 쓰레드 환경이므로 싱글톤 객체(서블릿, 스프링 빈)은 주의해서 사용
      • 단점) 사용 비용이 높다, 스위칭 비용 발생, 임계점 이상의 요청이 오면 서버 다운
      • 해결방안) 쓰레드 풀 : 쓰레드를 미리 쓰레드풀에 적재해놓고 사용, 허용량 이상 요청 시 대기 또는 거절
        • 장점 : 스위칭 비용이 절약, 응답시간 단축, 과요청 시에도 안전하게 처리 가능
    • 실무 Tip
      • 주요 튜닝 포인트는 최대 쓰레드(max thread) 수(성능테스트로 판단, 툴:아파치 ab, 제이미터 nGrinder)

    HTTP API

    • JSON 형식으로 데이터를 요청받고 반환하는 방식.
    • 앱,웹,서버 to 서버

    backend 개발자 웹 개발시 고려사항 3가지

    1. 정적페이지 어떻게 제공할건지(HTML)
    2. 동적 페이지 어떻게 제공할건지(WAS, JSP, 타임리프 -> HTML)
    3. API 어떻게 제공할건지(JSON방식)

    SSR, CSR

    • SSR - 서버 사이드 렌더링(백엔드), 필수적

      • 정적이고 복잡하지 않은 화면에 사용
      • HTML을 서버에서 만들어서 웹 브라우저에 전달
      • JSP, 타임리프 사용
    • CSR - 클라이언트 사이드 렌더링(프론트엔드)

      • HTML을 동적으로 만들어주는 자바스크립트 사용
      • ex) 구글 지도
      • 관련 기술 : React, Vue
    • 참고 : SSR에서도 자바스크립트를 사용해서 화면 일부로 동적으로 변경 가능


    복습 + 궁금한점 ✔

    • 싱글톤의 기능은 @Configuration이 보장한다.(환경 설정 클래스를 CGLIB class로 변환해줌으로써)

    • AutoScaling이 쓰레드 요청 부하를 해결해줄 수 있는가?

    • lombok : @RequiredArgsConstructor로 final 생성자를 자동으로 생성해주는 기능이다.


    참고(References)

    • 인프런 '김영한' 강사님의 "스프링 MVC 1편"

    'Spring' 카테고리의 다른 글

    Spring @Valid와 BindingResult 파라미터  (0) 2021.12.21
    Spring Controller Model model  (0) 2021.12.21
    스프링 구조의 이해  (0) 2021.11.30
    MVC 프레임워크 생성  (0) 2021.11.28
    HTTPServletRequest, Response, HTTP-API  (0) 2021.11.25
Designed by Tistory.