일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- web
- 알고리즘 연습
- AWS
- 장고
- 파이썬 알고리즘
- django widget
- js
- java
- DRF
- react
- API
- HTML
- PYTHON
- javascript
- Django
- django rest framework
- CSS
- 알고리즘 문제
- Baekjoon
- 알고리즘 풀이
- MAC
- 백준
- es6
- 알고리즘
- django ORM
- Algorithm
- Git
- form
- 파이썬
- c++
- Today
- Total
수학과의 좌충우돌 프로그래밍
[WEB] google이 만든 RPC, gRPC란 본문
gRPC란
gRPC
는 구글에서 개발한 어디서나 실행할 수 있는 오픈소스 고성능 RPC 프레임워크입니다.
RPC는 Remote Procedure Call의 줄임말로 원격 프로시저 호출이라고 합니다. 이는 별도의 원격제어를 위한 코딩없이 다른 주소공간에서 함수나 프로시저를 실행할 수 있게 해주는 프로세스간 통신 기술입니다.
특히 MSA 구조에서 각각의 서버가 다른 언어와 프레임워크로 개발되었을 경우에도 RPC는 문제 없이 서버간의 통신이 가능해집니다.
또한 기존의 REST 방식의 경우에는, 표준이 없어 파라미터의 응답이 명시적이지 않았을 뿐 아니라 JSON 형태의 데이터를 Serialization하는 비용이 발생한다는 단점이 있었습니다.
RPC는 이러한 문제점까지 해결하며 사용이 많아지고 있습니다.
Stub
RPC의 핵심 개념은 Stub
입니다.
서버와 클라이언트는 다른 주소 공간을 사용하고 있습니다.
그렇기 때문에 함수호출에 사용되는 매개변수를 변환하는 작업이 필요합니다.
안그러면 메모리 매개변수에 대한 포인터가 다른 데이터를 가리키게 됩니다.
이 변환을 담당하는 것이 바로 Stub
입니다.
Marshalling과 Unmarshalling
Stub은 클라이언트와 서버 각각에 존재합니다.
client Stub은 함수 호출에 사용될 파라미터를 변환합니다. 이를 Marshalling
이라고 합니다.
또한 서버에서 넘어온 결과를 변환합니다.
server Stub은 클라이언트가 전달한 매개변수를 역변환합니다. 이를 Unmarshalling
이라고 합니다.
또한 함수 실행 결과를 변환합니다.
RPC의 동작 방식
- Client가 Client Stub 호출
- Client Stub가 파라미터를 표준 포맷으로 변경
- Client Stub가 transport layer로 Server Stub에게 메세지 전송
- Server Stub은 프로시저 호출
- 프로시저가 완료되면 Server Stub으로 반환
- Server Stub가 transport layer로 Client Stub에게 메세지 전송
- Client Stub은 반환 값을 변환하여 Client에게 전달
gRPC의 특징
HTTP/2
gRPC
는 HTTP/2를 사용합니다.
이는 HTTP/1.1에 비해 여러 측면에서 장점을 가지고 있으며 이에 대한 자세한 내용은 아래 링크에서 참고할 수 있습니다.
https://ssungkang.tistory.com/entry/%EB%84%A4%ED%8A%B8%EC%9B%8C%ED%81%AC-HTTP-11-VS-HTTP-20
Protocol Buffer
프로토콜 버퍼는 JSON, XML과 마찬가지로 직렬화 데이터 구조입니다.
프로토콜 버퍼는 다른 구조에 비해 데이터의 크기가 작습니다.
아래 예시를 봅시다.
아래 데이터를 JSON으로 표현한 경우 82byte의 크기가 사용되었습니다.
{
"userName":"Martin",
"favouriteNumber":1337,
"interests":["daydreaming","hacking"]
}
하지만 이를 프로토콜 버퍼로 표현한다면 33byte로 표현 가능합니다.
어떻게 프로토콜 버퍼가 데이터를 표현하는지 위 그림에 나와있습니다.
필드명을 굳이 전부 표시하지 않고 5bit로 field tag에 숫자로 표현합니다.
또한 뒤에 3bit를 통해 type을 명시하며, 그 다음 byte에서는 데이터의 길이를 나타냅니다.
위 처럼 저장되면 사람이 보고 이해할 수 없기 때문에 proto
확장자를 가진 파일로 데이터에 대한 설명을 명시합니다.
message Person {
required string user_name = 1;
optional int64 favourite_number = 2;
repeated string interests = 3;
}
이를 통해 데이터의 크기를 최소화하고 통신을 더 빠르게 할 수 있습니다.
RPC의 단점
gRPC에 대해 알아보고 있지만 gRPC의 단점은 기존 RPC의 단점과 동일하여 이에 대해 알아보겠습니다.
인간이 읽기 부적합
위에서 말한 proto
파일이 없을 경우에는 사람이 데이터를 해독하기에 어렵습니다.
따라서 유저와 직접적으로 소통하는 클라이언트일 경우 RPC 사용하기에 부적절합니다.
그렇기 때문에 내부 서비스간에 많이 사용됩니다.
proto 문법
proto
파일을 작성하기 위한 문법을 숙지해야 합니다.
'웹프로그래밍 > 이론' 카테고리의 다른 글
[WEB] REST API 란 (0) | 2021.06.14 |
---|---|
[WEB] GraphQL, REST API의 대체? (0) | 2021.05.31 |
[WEB] JWT를 어디에 보관해야할까 (0) | 2021.05.23 |
[WEB] Authentication (2) JWT (0) | 2021.05.18 |
[WEB] URI vs URL vs URN 비교 분석 (0) | 2020.10.19 |