본문 바로가기
CS/개발자필수지식

[CS] API 개념

by Johnny's 2023. 8. 18.

API 개념

API (API, Application Programming Interface)둘 이상의 컴퓨터 프로그램이 서로 통신하는 방법이자 컴퓨터 사이에 있는 중계 계층을 의미

 

예를 들어 A라는 컴퓨터가 요청을 하B라는 컴퓨터가 응답을 한다고 했을 때의 어떻게 통신할 것인지, 어떠한 데이터를 주고 받을 건지 등에 대한 방법(HTTP, HTTPS 프로토콜을 사용할 것인지, GET, POST 등의 방식 등..)이 정의된 중계계층을 말함

 

참고로 API는 과거부터 발전되어온 용어로 라이브러리 및 프레임워크를 설명하는 명세서, 웹상에서 WEB API, Web Socket API 등을 가리키는데 현재를 기준으로 API라고 할 때 보통 WEB API를 기준으로 설명

 

인터페이스

인터페이스(interface)는 서로 다른 두 개의 시스템, 장치 사이에서 정보나 신호를 주고받는 경우의 접점이나 경계면임. 이를 통해 해당 컴퓨터의 내부서버가 어떻게 구현되어있는지는 상관없이 인터페이스를 통해 통신 등이 가능

 

API의 작동방식

API는 다음과 같이 중계계층으로 작동

 

사용자가 브라우저를 통해서 서버에 요청을 하게 되면 API가 중계계층 역할을 하며 요청을 처리

직접 서버의 데이터베이스에 접근 하는 것을 방지하기도 함

 

ex) https://www.naver.com

네이버의 화면은 여러 API들의 응답 값 등으로 이루어져 있음

 

API의 종류

1. 제공자는 서비스의 중요한 부분을 드러내지 않아도 됨
ex) DB 설계 구조나 드러내고 싶지 않은 데이터베이스의 테이블 정보, 서버의 상수값 등을 드러내지 않고 드러내고 싶은 부분만을 드러낼 수 있음

2. 사용자는 해당 서비스가 어떻게 구현되는지 알 필요없이 필요한 정보만을 받을 수 있음
3. OPEN API의 경우 앱 개발 프로세스를 단순화 시키고 시간과 비용을 절약할 수 있음
ex) 로그인 : https://developers.naver.com/products/login/api/api.md

4. 내부 프로세스가 수정되었을 때 API를 매번 수정하는 것이 아닌 API가 수정이 안 되게 만들 수 있음. 이를 통해 내부 DB, 서버의 로직이 변경이 되어도 매번 사용자가 앱을 업데이트하는 일은 줄어들 수 있음
ex) DB튜닝

5. 제공자는 데이터를 한곳에 모을 수 있음. 
ex) 예스24라는 책을 파는 쇼핑몰을 만들었다고 하면 해당 사이트에 방문하는 방문자, 어떤 특정한 것을 클릭하는 사용자에 대한 이벤트를 집계하고 싶을 때 해당 API를 만들고 해당 이벤트가 발생하면 해당 API를 호출하게 만들면 해당 데이터를 한 곳에 모을 수 있음. yes24의 베스트셀러, 검색페이지에서의 사용자이벤트

 

API의 종류

- private : 내부적으로 사용, 주로 해시키를 하드코딩해놓고 이를 기반으로 서버와 서버간의 통신함. 이는 비즈니스 파트너와도 사용될 수 있음. 비밀스럽게 해당 파트너와 해시키를 공유해 통신
public : 모든 사람이 사용할 수 있음. 많은 트래픽을 방지하기 위해 하루 요청수의 제한, 계정당 몇개 등으로 관리

 

* 참고

- CS 지식의 정석 | 디자인패턴 네트워크 운영체제 데이터베이스 자료구조 -인프런

댓글