-
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가지
- 정적페이지 어떻게 제공할건지(HTML)
- 동적 페이지 어떻게 제공할건지(WAS, JSP, 타임리프 -> HTML)
- 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