[TIL] REST / REST API

go286·2021년 3월 14일
0
post-thumbnail

1️⃣ REST란?

  • 자원의 이름으로 구분하여 해당 자원의 정보를 주고 받는 것을 의미한다.

✅ 자원(resource)의 표현(representation)에 의한 상태 전달

  • DB의 학생 정보가 자원일 때, 'students'를 자원의 표현으로 정한다.

✅ 정보 전달

  • 데이터가 요청되어지는 시점에서 자원의 정보를 전달
  • JSON 혹은 XML를 통해 데이터를 주고 받는 것이 일반적이다.

2️⃣ REST의 구체적인 개념

HTTP URL를 통해 자원을 명시하고, HTTP Method를 통해 해당 자원에 대한 CRUD Operation을 적용하는 것을 의미한다.

3️⃣ REST의 장단점

✅ 장점

  • HTTP 프로토콜의 인프라를 그대로 사용하므로 REST API 사용을 위한 별도의 인프라를 구축할 필요가 없다.
  • REST API 메시지가 의도하는 바를 명확하게 나타내므로 의도하는 바를 쉽게 파악할 수 있다.
  • 서버와 클라이언트의 역활을 명확하게 분리한다.

✅ 단점

  • HTTP Method 형태가 제한적이다.
  • 구형 브라우저가 PUT, DELETE를 지원해주지 않는다.

4️⃣ REST 특징

✅ Server-Client(서버-클라이언트 구조)

  • 자원이 있는 쪽이 Server, 자원을 요청하는 쪽이 Client가 된다.
  • 서로간에 의존성이 줄어든다.

✅ Stateless(무상태)

  • HTTP 프로토콜은 Stateless Protocol이므로 REST 역시 무상태성을 갖는다.
  • Client의 context를 Server에 저장하지 않는다.
  • Server는 각각의 요청을 완전히 별개의 것으로 인식하고 처리한다.

✅ Cacheable(캐시 처리 가능)

  • 캐시 사용을 통해 응답시간이 빨라지고 REST Server 트랜잭션이 발생하지 않기 때문에 전체 응답시간, 서버의 자원 이용률을 향상시킬 수 있다.

✅ Layered System(계층화)

  • Client는 REST API Server만 호출한다.
  • API Server는 순수 비즈니스 로직을 수행하고 그 앞단에 보안, 로드밸런싱, 암호화, 사용자 인증 등(다층 계층)을 추가하여 구조상의 유연성을 줄 수 있다.

✅ Uniform Interface(인터페이스 일관성)

  • URI로 지정한 Resource에 대한 조작을 통일되고 한정적인 인터페이스로 수행한다.
  • 특정 언어나 기술에 종속되지 않는다.

5️⃣ REST API란?

REST 기반으로 서비스 API를 구현한 것

6️⃣ REST API 특징

  • 사내 시스템들도 REST 기반으로 시스템을 분산해 확장성과 재사용성을 높여 유지보수 및 운용을 편리하게 할 수 있다.
  • REST는 HTTP 표준을 기반으로 구현하므로, HTTP를 지원하는 프로그램 언어로 클라이언트, 서버를 구현 할 수 있다.

7️⃣ REST API 설계 기본 규칙

  • URI는 정보의 자원을 표현해야 한다.
  • 자원에 대한 행위는 HTTP Method로 표현한다.

8️⃣ RESTful이란?

  • 일반적으로 REST라는 아키텍처를 구현하는 웹 서비스를 나타내기 위해 사용되는 용어이다.

9️⃣ RESTful의 목적

  • 이해하기 쉽고 사용하기 쉬운 REST API를 만드는 것
  • RESTful한 API를 구현하는 근본적인 목적이 성능 향상에 있는 것이 아니라 일관적인 컨벤션을 통한 API의 이해도 및 호환성을 높이는 것이 주 동기이니, 성능이 중요한 상황에서는 굳이 RESTful한 API를 구현할 필요는 없다.

참조

https://gmlwjd9405.github.io/2018/09/21/rest-and-restful.html

0개의 댓글