앱에서 상품 정보 같은 리소스가 존재하는 곳과 리소스를 사용하는 앱을 분리시킨 것을
2티어 아키텍처
또는클라이언트-서버 아키텍처
라고 한다. 리소스를 사용하는 앱이클라이언트
, 리소스를 제공하는 곳을 서버라고 부른다.
리소스에 접근하는 앱은 손님(Client) -- 요청 --> 리소스를 가지고 있는 점원(Server), 점원은 리소르르 담아 응답한다.
프로토콜이란? 통신 규약, 웹 애플리케이션 아키텍처에서는 HTTP라는 프로토콜을 이용해 메세지를 주고받는다.
API란? Application Programming Interface로 서버는 클라이언트에게 리소스를 잘 활용하도록 인터페이스를 적용해줘야한다.
서버는 리소스 전달을 위해 API문서
(메뉴판)를 작성해 클라이언트가 활용할 수 있고, 인터넷에 있는 데이터를 요청할 때에는 HTTP 프로토콜
을 사용하며, 주소(URL,URI)
를 통해 접근할 수 있다.
:scheme: :hosts: :url-path: :query:
file://127.0.0.1/Users/username/Desktop/
http://www.google.com:80/search?q=JavaScript
크롬 브라우저에 다음과같은 url을 입력하면 파일 탐색기를 사용할 수 있다.
query fragment
를 포함, 웹 서버에 보내는 추가적인 질문 q-JavaScript
를 통해 JavaScritpt를 검색한 결과가 나타난다.#
)는 일종의 북마크 역할,특정 PC의 주소를 나타내는 체계 (Internet Protocol address, IP 주소)
IPv4 닷(.
)으로 구분된 네덩이의 숫자로 표현 -> IPv6
IP 주소가 가리키는 PC에 접속할 수 있는 통로(채널)을 의미한다.
- 22 : SSH
- 80 : HTTP
- 443: HTTPS
IP 주소를 대신하여 사용하는 주소, IP 주소가 도로명주소라면 도메인은 해당 주소에 위치한 상호라고 할 수 있다.
네트워크 상 모든 PC는 IP주소가 있지만 모두 도메인 이름을 가지는것은 아니다. DNS는 호스트의 도메인 이름을 IP 주소로 변환하거나 반대의 경우를 수행할 수 있도록 개발된 데이터베이스 시스템이다.
naver.com을 입력한다면, DNS에서 IP 주소(ex.125.209.222.142)를 찾습니다. 그리고 이 IP 주소에 해당하는 웹 서버로 요청을 전달하여 클라이언트와 서버가 통신할 수 있도록 한다.
❖ IP - 공동현관, PORT - 각 세대, DNS - 전화번호부
HyperText Transfer Protocol로, HTML과 같은 문서를 전송하기 위한 프로토콜이다. 전통적인 클라이언트-서버 모델에서 클라이언트가 HTTP Messages 양식에 맞춰 요청을 보내면, 서버도 HTTP Messages 양식에 맞춰 응답한다.
클라이언트와 서버 사이에 데이터가 교환되는 방식
- 요청
- 응답
요청
과응답
은 다음과 같은 구조를 가진다.
start line
: start line에는 요청이나 응답의 상태를 나타냅니다. 항상 첫 번째 줄에 위치합니다. 응답에서는 status line이라고 부릅니다.HTTP headers
: 요청을 지정하거나, 메시지에 포함된 본문을 설명하는 헤더의 집합입니다.empty line
: 헤더와 본문을 구분하는 빈 줄이 있습니다.body
: 요청과 관련된 데이터나 응답과 관련된 데이터 또는 문서를 포함합니다. 요청과 응답의 유형에 따라 선택적으로 사용합니다.상태를 가지지 않는다는 뜻, HTTP로 클라이언트와 서버가 통신을 주고받는 과정에서, HTTP가 클라이언트나 서버의 상태를 확인하지 않는다.
Stateless 특성때문에 저런 http 메세지에 정보를 담는다.
클라이언트가 서버에게 보내는 메세지
서버가 클라이언트에게 보내느 메세지
클라이언트에서 데이터를 요청 --> 요청받을 데이터를 토대로 응답을 전송
관리자 계정만 들어갈 수 있는 관리자 페이지에 일반 사용자 계정으로 접근했을 때 403이 뜬다.
Asynchronous JavaScript And XMLHttpRequest의 약자로, JavaScript, DOM, Fetch, XMLHttpRequest, HTML 등의 다양한 기술을 사용하는 웹 개발 기법이다.
ex) 마우스 올려두면 변화
최초 접속시에만 데이터를 받아오고 그후에는 요청에 따라 전달받은 데이터를 자바스크립트로 받아옴
Fetch를 이용하면 페이지를 이동하지 않아도 서버로부터 필요한 데이터를 받아올 수 있다.
서버에서 HTML을 완성하여 보내주지 않아도 웹페이지를 만들 수 있다.
표준화된 방법
이전에는 브라우저마다 다른 방식으로 AJAX를 사용했으나, XHR이 표준화되면서부터 브라우저에 상관없이 AJAX를 사용할 수 있게 되었다.
AJAX를 사용하면 필요한 일부분만 렌더링하기 때문에 빠르고 더 많은 상호작용이 가능한 애플리케이션을 만들 수 있다.
대역폭: 네트워크 통신 한 번에 보낼 수 있는 데이터의 크기
이전에는 서버로부터 완성된 HTML 파일을 받아와야 했기 때문에 한 번에 보내야 하는 데이터의 크기가 컸습니다. 그러나 AJAX에서는 필요한 데이터를 텍스트 형태(JSON, XML 등)로 보내면 되기 때문에 비교적 데이터의 크기가 작다.
AJAX 방식의 웹 애플리케이션은 한 번 받은 HTML을 렌더링 한 후, 서버에서 비동기적으로 필요한 데이터를 가져와 그려냅니다. 따라서, 처음 받는 HTML 파일에는 데이터를 채우기 위한 틀만 작성되어 있는 경우가 많습니다. 검색 사이트에서는 전 세계 사이트를 돌아다니며 각 사이트의 모든 정보를 긁어와 사용자에게 검색 결과로 보여줍니다. AJAX 방식의 웹 애플리케이션의 HTML 파일은 뼈대만 있고 데이터는 없기 때문에 사이트의 정보를 긁어가기 어렵다.
일반적으로 사용자는 뒤로가기 버튼을 누르면 이전 상태로 돌아갈 거라고 생각하지만, AJAX에서는 이전 상태를 기억하지 않기 때문에 사용자가 의도한 대로 동작하지 않습니다. 따라서 뒤로가기 등의 기능을 구현하기 위해서는 별도로 History API를 사용해야한다.
SSR은 Server Side Rendering로 웹페이지를 브라우저에서 렌더링하지 않고 서버에서 렌더링한다. 브라우저가 서버의
URI
로GET
요청을 보내면, 서버는 정해진 웹 페이지 파일을 브라우저로 전송한다.
CSR은 Client Side Rendering로 SSR의 반대이다. 클라이언트에서 페이지를 렌더링하며 웹 페이지의 골격이 될 단일 페이지(Single Page)를 클라이언트에 보낸다. 이때 서버는 웹 페이지와 함께 JavaScript 파일을 보낸다.
SSR과 CSR의 주요 차이점은 페이지가 렌더링되는 위치입니다. SSR은 서버에서 페이지를 렌더링하고, CSR은 브라우저(클라이언트)에서 페이지를 렌더링한다. CSR은 사용자가 다른 경로를 요청할 때마다 페이지를 새로고침 하지 않고, 동적으로 라우팅을 관리한다.
CSR은 TTI와 TTV가 같음
SSR은 ttv가 느림 --> SSR을 사용할때는 두 시간차를 줄이는게 중요함
html,css,js 렌더링에 필요한걸 자바스크립트를 통해 한번에 하기때문에
tti
: 새로고침 후 클릭(이벤트)할때까지 걸리는 시간
ttv
: 새로고심 후 화면에 나타나는데 걸리는 시간