IT/용어

[용어] REST/REST API/RESTful

Ma_Sand 2022. 8. 22. 22:29
반응형

REST(Representational State Transfer)

 자원을 이름으로 구분하여 해당 자원의 상태를 주고받는 모든 것을 의미한다. 즉, 자원의 표현(representation)에 의한 상태 전달을 말한다. REST는 ROA(Resource Oriented Architecture)를 따르는 웹 서비스 아키텍쳐이다.

 구체적인 의미로는 HTTP URI(Uniform Resource Identifier)를 통해 자원을 명시하고, HTTP Method(POST, GET, PUT, DELETE)를 통해 해당 자원에 대한 CRUD Operation을 적용하는 것을 의미한다.

 

REST CRUD Operation
 - Create: 생성(POST)
 - Read: 조회(GET)
 - Update: 수정(PUT)
 - Delete: 삭제(DELETE)

 

즉, "URI와 HTTP 메소드를 이용하여 객체화된 서비스에 접근하는 것"이라고 말할 수 있다. 직관적인 URI를 이용하여 오브젝트의 멤버를 추적하는 것처럼 리소스에 접근하여 HTTP 메소드를 이용해 그것을 조작하는 것이다.

 

 

1. REST의 특징

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

자원 있는 쪽이 Server, 자원 요청하는 쪽이 Client이다. REST Server는 API를 제공하고 비즈니스 로직 처리 및 저장을 책임진다. Client는 사용자 인증이나 Context(세션, 로그인 정보) 등을 직접 관리하고 책임진다. 또한 REST를 사용하면 서버와 클라이언트 간 의존성이 줄어든다.

 

 (2) 무상태(Stateless)

이전, 이후에 대한 직접적인 정보가 필요없이 직관적인 오브젝트로의 접근으로 서비스를 처리한다. 세션 정보를 보관할 필요가 없어 서비스의 자유도 또한 높아지고, 로드밸런싱이나 기타 유연한 아키텍쳐의 적용이 가능하며, 쿠키와 세션이 필요 없어진다.

 

 (3) 캐시 처리 가능(Cacheable)

웹 표준 HTTP 프로토콜을 그대로 사용하므로 웹에서 사용하는 기존의 인프라를 그대로 활용할 수 있다. 캐시 사용을 통해 응답시간이 빨라지고 REST Server 트랜잭션이 발생하지 않기 때문에 전체 응답시간, 성능, 서버의 자원 이용률을 향상시킬 수 있다.

 

 (4) 계층화(Layered System)

클라이언트는 REST APU Server만 호출한다. REST Server는 다중 계층으로 구성될 수 있다. 프록시, 게이트웨이 같은 네트워크 기반의 중간 매체를 사용할 수 있다.

 

 (5) URI 접근(Addressability)

REST는 모든 유일한 오브젝트에 대해 유일하고 직관적인 URI를 통해 접근토록 한다. 웹 사이트의 이미지, 텍스트, DB 내용 등의 모든 자원에 고유한 ID인 HTTP URI를 부여한다.

 

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

URI로 지정한 리소스 조작을 통일되고 한정적인 인터페이스로 수행한다.

 

 

2. REST의 장/단점

 (1) 장점

- HTTP 프로토콜의 인프라를 그대로 사용하기 때문에 REST API 사용을 위한 별도의 인프라를 구축할 필요 없다.
- HTTP 프로톨의 표준을 최대한 활용하여 여러 추가적인 장점을 함께 사용할 수 있다.
- HTTP 표준 프로토콜에 따르는 모든 플랫폼에서 사용이 가능하다.
- Hypermedia API의 기본을 충실히 지키면서 범용성을 보장한다.
- REST API 메시지가 의도하는 바를 명확하게 나타내므로 이를 쉽게 파악할 수 있다.
- 여러 가지 서비스 디자인에서 생길 수 있는 문제를 최소화한다.
- 서버와 클라이언트의 역할을 명확하게 분리한다.

 

 (2) 단점

- 표준이 존재하지 않는다.
- 사용할 수 있느 메소드가 네 가지 밖에 없다.
- HTTP Method 형태가 제한적이다.
- 구형 브라우저가 지원해주지 못하는 부분(PUT, DELETE, pushState)이 존재한다.

 

 

3. REST가 필요한 시점

 (1) 애플리케이션 분리 및 통합을 해야할 때

 (2) 다양한 클라이언트들이 등장했을 때

 (3) 다양한 브라우저, 안드로이드폰, 아이폰과 같은 모바일 디바이스에서도 통신 가능한 서버 프로그램이 필요할 때

 (4) 멀티 플랫폼에 대한 지원을 위해 서비스 자원에 대한 아키텍처가 필요할 때

 

 


 

REST API

 REST 기반으로 서비스 API를 구현한 것을 말한다. 최근 오픈 API(구글 맵, 공공 데이터 등), 마이크로 서비스(하나의 큰 애플리케이션을 여러 개의 작은 애플리케이션으로 쪼개 변경과 조합이 가능하도록 만든 아키텍처) 등을 제공하는 업체의 대부분은 REST API를 제공한다.

 

REST API의 특징
- 사내 시스템들도 REST 기반으로 시스템을 분산해 확장성과 재사용성을 높여 유지보수 및 운용을 편리하게 할 수 있다.
- REST는 HTTP 표준을 기반으로 구현하므로 HTTP를 지원하는 프로그램 언어로 클라이언트와 서버를 구현할 수 있다.
- REST API를 제작하면 델파이 클라이언트 뿐만 아니라 Java, C#, Web 등을 이용하여 클라이언트를 제작할 수 있다.

 

 

 


RESTful

 REST라는 아키텍처를 구현하는 웹 서비스를 나타내기 위해 사용되는 용어이다. REST API를 제공하는 웹 서비스를 RESTful하다고 할 수 있다. 즉, REST 원리를 따르는 시스템은 RESTful이란 용어로 지칭된다.

 

RESTful하지 못한 경우
- CRUD 기능을 모두 POST로만 처리하는 API
- 라우트(route)에 리소스, 아이디 외의 정보가 들어가는 경우

 

 

 

 

 

[출처] Heee's Development Blog https://gmlwjd9405.github.io/2018/09/21/rest-and-restful.html

 

[Network] REST란? REST API란? RESTful이란? - Heee's Development Blog

Step by step goes a long way.

gmlwjd9405.github.io

 

 

 

 

 

 

반응형