목차
0. 웹 서버는 어떻게 동작하나?
0. 클라이언트는 웹 브라우저를 통해 특정 사이트에 접속하기 위해 웹 서버에 요청을 보냅니다.
1. 요청을 접수한 웹 서버에서는 컨텐츠가 정적인지, 동적인지 판단합니다.
2. 정적 컨텐츠면 웹 서버 내부의 디스크에 있는 정보를 취득해 클라이언트로 보내고,
2.1 동적 컨텐츠면 스위치를 경유해 WAS 서버로 요청을 보냅니다.
3. WAS 에서는 요청을 접수하고 자신이 처리할 수 있는 지, DB 접속이 필요한지 판단합니다.
3.1 자신이 처리가 가능하면 요청을 바탕으로 처리 후 웹 서버(web server)로 결과를 파일 데이터로 반환합니다.
3.2 DB 접속이 필요하면 DB 서버에 요청을 보내고, 요청을 받은 DB는 데이터를 반환해서 WAS로 결과를 반환합니다.
4. 결과를 반환받은 WAS는 웹 서버(Web Server)로 보내고, 클라이언트에게 반환합니다.
1. Was와 Web Server의 차이
1. Web Server (웹 서버)란?
Web Server는 브라우저의 요청에 따라 정적 컨텐츠를 제공하는 서버입니다.
(정적 컨텐츠 : 실시간으로 변경할 필요가 없는 데이터로 웹 서버의 디스크 저장을 해두고 요청에 따라 웹 서버에서 클라이언트로 반환 ex) 회사 로고 )
웹 서버는 HTTP 프로토콜을 기반으로 클라이언트의 요청을 서비스 하는 기능을 담당합니다.
클라이언트의 요청을 WAS에 보내고, WAS가 처리한 결과를 클라이언트에게 전달합니다.
1.1 대표적인 예시
ex) Nginx, Apache server
1.2 Web Server가 왜 필요할까요?
이미지 및 정적 파일은 웹 문서인 Html이 클라이언트로 보내질 때 함께 가는 것이 아니라,
2. Web Application Server, WAS ( 웹 애플리케이션 서버 )란?
Was는 Web Server에서 넘어온 동적 컨텐츠 및 여러 기능들을 제공하는 Application Server입니다.
(동적 컨텐츠 : 자주 변경되는 데이터, 사용자의 요청에 따라 변화의 유무가 있는 데이터 ex) 은행 잔고, 쇼핑몰 장바구니)
웹 컨테이너 혹은 서블릿 컨테이너라고도 불리며 HTTP를 통해 컴퓨터나 장치에 애플리케이션을 수행해주는 미들웨어(소프트웨어 엔진)로 비즈니스 로직을 수행하고, 프로그램 실행 관경과 DB 접속 기능 제공합니다.
2.1 대표적인 예시
ex) Tomcat, WebSphere
3. WAS와 Web Server를 분리하는 이유 및 분리하면 얻을 수 있는 장점들
Was는 Web Server의 역할을 다 할 수 있지만, 분리해서 사용하는게 성능상으로 좋습니다.
그 이유는 웹 페이지에는 동적, 정적 컨텐츠가 모두 존재하는데, 만약에 한 서버를 이용해서 모두를 처리해버리면 자연스레 부하가 따라올 수 밖에 없다. 그래서 단순한 컨텐츠인 정적 컨텐츠는 앞단인 웹 서버를 이용해서 처리하는 것이 좋습니다.
Was에 정적 컨텐츠까지 처리하게되면 부하가 커지고 수행속도가 느려집니다.
SSL에 대한 암호화 및 복호화 처리에 웹 서버를 사용가능하기에 보안을 강화할 수 있습니다.
로드 밸런싱(Load Balancing)을 위해 web Server를 사용하는데, 대용량 웹 어플리케이션의 경우에 여러대의 서버를 사용해서 Web과 WAS를 분리해서 무중단 운영을 위한 장애 극복에 쉽게 대응할 수 있습니다.
그래서 웹 서버(Web Sever)를 was 앞에 두고 필요한 WAS 들을 Web Server에 플러그인 형태로 설정하면 효율적인 분산처리가 가능합니다.
참고 레퍼런스
2. 트랜잭션은 무엇인가?
트랜잭션은 데이터베이스에 요청한 작업이 진행되는 작업의 단위입니다. 만약 우리가 데이터베이스에 어떤 요청을 진행했을 때, 해당 작업이 동시에 진행되어야 하는 작업인데 데이터베이스의 입장에서 작업의 단위를 묶어주지 않으면 동시에 진행되어야 하는 작업임을 인지하지 못합니다. 그래서 내가 원하는 결과를 얻지 못할 것입니다. 그래서 이 작업의 단위로 묶어주는 트랜잭션이 중요합니다.
이 트랜잭션은 4가지의 특징을 가지고 있습니다.
- 원자성 : 트랜잭션 내 실행한 작업들은 하나로 간주해서 모두가 성공(commit)하거나 모두가 실패(rollback)되어야 합니다.
- 일관성 : 데이터베이스의 고정 요소에 대해 트랜잭션의 전과 후에는 일관성있는 상태를 유지해야 하며, 트랜잭션이 실행되어 결과가 반영되어도 일관성 있는 상태를 유지해야 합니다.
- 격리성 : 동시에 실행되는 트랜잭션들은 서로 영향을 미치지 않도록 격리해야합니다.
- 영속성(지속성) : 트랜잭션에 반영된 내용들은 결과를 항상 저장해야합니다.
과거에 작성한 트랜잭션 관련 정리내용 참고하기
'기술면접 관련 및 참고하기' 카테고리의 다른 글
기술 면접 스터디 - 8회차 ( 시간 복잡도와 공간복잡도, 오버라이딩, 오버로딩) (0) | 2023.04.06 |
---|---|
기술 면접 스터디 7회차 - ( Stack, Queue, Array, LinkedList, 절차지향, 객체지향, 함수형 프로그래밍) (0) | 2023.04.05 |
기술 면접 스터디 5일 -( 프로세스와 스레드, TCP와 UDP) (0) | 2023.03.31 |
GC (Garbage Collection)이란 무엇인가? (0) | 2023.03.31 |
기술 면접 스터디 4일차 - ( List, Set, Map, Hash Map, Parameter, Argument) (0) | 2023.03.30 |