Devops/DevOps

서버리스 서비스 비교

2mukee 2024. 8. 12. 00:04
320x100
320x100

사전지식

- vCPU초

보통 1Ghz 당 1초 기준으로 산정

인스턴스 실행 시 1Ghz만큼의 CPU 점유가 발생하는 경우 1초이고, 0.25Ghz면 4초가 됨

24만 Ghz초면 1Ghz일 경우 24만초, 0.25Ghz일 경우 96만초가 됨

 

- 메모리 GB초

보통 1GB당 1초 기준으로 산정

인스턴스 실행 시 1GB만큼의 메모리 점유가 발생하는 경우 1초, 256MB면 4초가 됨

45만 GB초면 1GB일 경우 45만초, 256MB일 경우 180만초가 됨

 

 

 

 

AWS Lambda

AWS에서 제공하는 대표적인 서버리스 서비스

람다 함수는 아마존 S3로의 객체 업로드, 아마존 SNS 알림, API 동작과 같은 이벤트에 반응하여 실행됨

람다 함수는 자동으로 500MB의 임시 스크래치 디렉터리를 받으며

영구 상태를 위해 아마존 S3, 아마존 다이나모 DB 및 기타 인터넷 스토리지 서비스를 사용할 수 있음

람다 함수는 아마존 리눅스에서 지원되는 모든 언어를 사용해서 프로세스를 실행하고 라이브러리를 호출 할 수 있다

 

 

지원 언어

파이썬 / NodeJS / 루비 / 자바 / C# / 파워 셸 / Go

 

 

비용

프리티어의 경우 1GB 메모리 환경에서 월 100만 건 / 40만 GB초의 실행 시간을 무료 제공

프리티어에는 요청 당 6MB를 초과하는 월 100GB의 HTTP 응답 스트리밍까지 포함

단, 다른 지역에 실행중인 스토리지 서비스 간 데이터 전송 시 수수료 발생 가능

무료 사용량 초과후 요청 당 0.0000002 달러 / 컴퓨트 시간 GB초 0.00000025 달러 (메모리 1GB 시 1초당 0.00000025달러)

https://aws.amazon.com/ko/lambda/pricing/?trk=b28d8305-f5fb-4858-9ae6-04a78cfcc154&sc_channel=ps&s_kwcid=AL!4422!3!651510601848!e!!g!!lambda%20pricing&ef_id=Cj0KCQjwlIG2BhC4ARIsADBgpVR3E25NKfGXNFyepbhN85O2AkPQ38uVkPTWEGefXoS-WTEtpI29MtYaAg-cEALw_wcB:G:s&s_kwcid=AL!4422!3!651510601848!e!!g!!lambda%20pricing!19836398350!150095232634

 

서버리스 컴퓨팅 – AWS Lambda 요금 – Amazon Web Services

 

aws.amazon.com

 

 

 

스펙

최대 실행 시간 900초/15분

메모리 기본 128MB, 최대 3008MB까지 할당량 지원

환경변수 크기 최대 4KB

 

 

장점

AWS가 인프라를 관리해주기 때문에 개발자가 코드에만 집중할 수 있다

트래픽이 몰리면 자동으로 확장해주기 때문에 안정적으로 서비스를 제공할 수 있다

다양한 언어를 지원한다

다양한 AWS 서비스와 통합되어 있어, 람다 함수를 확장할 수 있다

 

- AWS 람다 엣지

아마존 클라우드 프론트 CDN 이벤트에 대응해 200개 이상의 AWS 엣지 위치에서 람다 함수를 실행할 수 있게 해준다

 

- AWS SAM (AWS Serverless Application Model)

서버리스 애플리케이션 및 서비스를 모델링하고 배포할 수 있도록 해주는 서버리스 애플리케이션 모델

 

- AWS 서버리스 애플리케이션 레포지터리

서버리스 애플리케이션과 애플리케이션 구성요소를 찾아서 재사용할 수 있게 해줌

아마존 클라우드 워치를 통해 모니터링이 가능하고, 아마존 X-Ray를 통해 분석 및 디버깅까지 지원

 

 

단점

함수가 처음 시작될 때 초기화가 필요하므로 응답 시간이 늦어질 수 있다

 > 이를 해결하기 위해 람다는 함수를 미리 초기화 해놓는 웜 스타트 라는 매커니즘을 제공

로깅 및 디버깅 기능이 제한적이므로 별도의 서비스를 사용해야한다 

함수를 실행할 수 있는 지역이 제한적이어서 특정 리소스를 사용할 수 없는 경우가 있다

 

 

 

 

 

 

 

 

 

MS Azure Function

복잡한 오케스트레이션 문제를 해결할 수 있는 이벤트 기반의 서버리스 컴퓨팅 플랫폼

클라우드에서 대규모로 설정, 배포, 운영할 필요없이 로컬에서 애저 펑션을 구축하고 디버깅 가능

트리거와 바인딩을 통해 서비스를 통합할 수 있다

 

 

지원 언어

C# / 자바 / 자바스크립트 / 파워셸 / 파이썬 / 타입스크립트

 

 

비용

월 100만 건 / 40만 GB초의 실행 시간을 무료 제공

유연한 사용량 플랜의 경우 25만 건 / 10만 GB초의 실행 시간을 무료 제공

콜드 부팅 없이 향상된 성능을 제공하는 프리미엄 플랜이 따로 존재

다른 Azure 클라우드 지역으로의 데이터 이동에 대해 요금을 부과하지 않음

무료 사용량 초과 후 100만 요청 당 0.2달러 / 실행시간 GB 당 0.000004 달러 (1GB 메모리 기준 초당 0.000004 달러)

https://azure.microsoft.com/ko-kr/pricing/details/functions/

 

가격 - 기능 | Microsoft Azure

Azure Functions는 강력한 이벤트 트리거 및 데이터 바인딩 집합을 지원하는 서버를 사용하지 않는 개발 환경을 제공합니다.

azure.microsoft.com

 

 

 

스펙

http 요청 최대 2.5분 / 이벤트 실행 최대 10분

 

 

장점

Azure가 인프라 관리를 담당하기 때문에 개발자는 코드에만 집중할 수 있음

이벤트 기반 트리거로 필요에 따라 자동으로 확장되어 안정적으로 서비스 제공 가능

다양한 언어를 지원

Azure 서비스와 통합하여 기능 확장 가능

 

 

단점

함수가 처음 시작될 때 초기화가 필요하므로 응답 시간이 늦어질 수 있다

 > 프리미엄 서비스를 이용하거나 듀어러블 펑션이라는 확장 프로그램을 통해 스테이트 풀 워크 플로우 정의 가능

10초에 하나의 function app 인스턴스가 생성되며 최대 200개의 인스턴스를 생성할 수 있기 때문에 호출이 많이 들어오면 처리를 못할 수 있다

 

 

 

 

 

 

Google Cloud Function

구글에서 제공하는 확장 가능한 종량제 FaaS 플랫폼

모니터링, 로깅, 디버깅 기능이 통합되어 있으며 역할 및 함수 수준에서의 보안을 내장함

하이브리드 클라우드와 멀티 클라우드 시나리오를 위한 주요 네트워킹 기능을 제공

트리거를 통해 구를 클라우드 또는 서드파티 클라우드 서비스에 연결하여 까다로운 오케스트레이션 문제를 원활하게 해결

 

 

지원 언어

Go / 자바 / nodeJS / 파이썬

 

 

비용

월 200만 건 / 메모리 40만 GB초, CPU 20만 Ghz초의 실행 시간, 5GB 아웃바운드 트래픽 무료 제공
무료 제공 초과 후 요청 당 0.0000004 달러 / 컴퓨트 시간 GB당 0.00001667 달러 (1GB 메모리 기준 초당 0.00001667 달러)

https://cloud.google.com/functions/pricing?hl=ko

 

가격 책정  |  Cloud Functions  |  Google Cloud

Cloud Functions 가격 책정 정보 검토

cloud.google.com

 

 

스펙

http 요청 최대 60분 / 이벤트 기반 함수 최대 9분

 

 

 

장점

일반적인 http 요청 및 클라우드 인프라에서의 이벤트 처리를 위한 백그라운드 함수 지원

클라우드 펑션의 자동 테스트 및 배포를 위한 클라우드 빌드 제공

깃허브, 비트버킷, 클라우드 소스 레포지터리와 같은 소스 코드 레포지터리와 연동하여 사용 가능

로컬 시스템에서 클라우드 펑션을 개발하고 배포 가능

GCP의 기능들과 연계 가능

 

 

단점

지원하는 언어가 적은 편이다

 

 

 

 

 

Google Cloud Run

컨테이너를 기반으로 서버리스를 제공하는 서비스

클라우드 펑션의 경우 함수를 직접 올리지만, 클라우드 런은 컨테이너를 올리기 때문에 언어에 대한 제약이 없으며, 컨테이너로 구동 가능한 어떤 것이든 서비스가 가능하다

 

 

지원언어

모든 언어

 

 

스펙

각 태스크 당 최대 10분 간 실행 가능

 

 

비용

200만 요청 / 메모리 45만 GB초 / CPU 24만 GHz 초 제공

무료 시간 초과 시 vCPU 1코어 사용 시간 초당 0.000018 달러 / 메모리 1GB 초당 0.000002 달러

https://cloud.google.com/run/pricing?hl=ko

 

가격 책정  |  Cloud Run  |  Google Cloud

Cloud Run 가격 책정 검토

cloud.google.com

 

 

 

장점

컨테이너를 사용하기 때문에 언어나 환경에 대한 제약이 적다

애플리케이션이나 웹 서비스를 서버리스로 배포할 수 있다

 

 

단점

다른 함수형 서버리스 서비스에 비해 비용이 비싸다 (인프라 빌리는 것보다는 훨씬 저렴함)

 

 

 

 

 

 

기타 서비스

- IBM 클라우드 펑션

- 오라클 클라우드 펑션
=> 이 둘은 자료도 적고 인지도가 낮기 때문에 차후 사용할 일이 있다면 정리해보도록 하겠다...

 

 

 

 

 

 

Preference

 

클라우드 서버리스 플랫폼을 선택하는 방법

클라우드에서 전체 용량으로 24/7 서버 팜을 운영할 경우 비용이 천정부지로 치솟을 수 있다. 필요 없을 때 용량의 대부분을 끌 수 있다면 어떨

www.itworld.co.kr

 

AWS Lambda 장단점과 운영의 어려움

AWS Lambda는 서버리스 아키텍처에서 가장 인기 있는 컴퓨팅 서비스 중 하나입니다. 이것은 개발자가 코드를 작성하고 배포할 때 인프라 관리에 대한 걱정을 덜어줍니다. 그러나 AWS Lambda는 실제 운

umanking.github.io

 

서버리스 컴퓨팅 – AWS Lambda 요금 – Amazon Web Services

 

aws.amazon.com

 

AWS Lambda 개념, 장단점, 사용목적

📚 목차 1. 개념 2. 장단점 3. 사용목적 참고자료 1. 개념 Amazon Web Service(AWS) Lambda는 이벤트가 발생했을 때 코드(=함수)를 실행하고 컴퓨터 리소스를 관리하는 Serverless 컴퓨팅 서비스입니다(그림 1

heytech.tistory.com

 

Azure Functions에서 지원되는 언어

Azure에서 Functions 개발에 지원하는 언어, 다양한 언어 버전의 지원 수준 및 잠재적인 지원 종료 날짜에 대해 알아봅니다.

learn.microsoft.com

 

가격 - 기능 | Microsoft Azure

Azure Functions는 강력한 이벤트 트리거 및 데이터 바인딩 집합을 지원하는 서버를 사용하지 않는 개발 환경을 제공합니다.

azure.microsoft.com

 

구글 클라우드의 서버리스 서비스 Cloud Functions

Google Cloud Function 조대협 (http://bcho.tistory.com)기본 개념구글 클라우드 펑션은 서버리스 아키텍쳐를 구현하기 위한 구글 클라우드 서비스이다. 아마존 웹서비스의 람다와 같은 기능이라고 보면 된

bcho.tistory.com

 

함수 제한 시간  |  Cloud Functions Documentation  |  Google Cloud

검색을 단순화하고 문서 이용 환경을 개선하기 위해 1세대 및 2세대 문서가 개별 집합으로 분할됩니다. 의견 보내기 컬렉션을 사용해 정리하기 내 환경설정을 기준으로 콘텐츠를 저장하고 분류

cloud.google.com

 

Google Cloud Functions vs AWS lambda

사용하기 뭐가 더 나을까

blog.toktokhan.dev

 

[GCP]Serverless 서비스인 Cloud Run 알아보기 1부 — Cloud Run 개요

안녕하세요 이정운 입니다.

medium.com

 

https://cloud.google.com/run?hl=ko

 

cloud.google.com

 

태스크 제한 시간 설정(작업)  |  Cloud Run Documentation  |  Google Cloud

의견 보내기 태스크 제한 시간 설정(작업) 컬렉션을 사용해 정리하기 내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요. 기본적으로 각 태스크는 최대 10분 동안 실행됩니다. 이 시간은 더

cloud.google.com

 

300x250
728x90