IT/AWS

[AWS] ECS vs Kubernetes

물통꿀꿀이 2019. 2. 8. 02:58

컨테이너 서비스인 AWS ECS와 Kubernetes에 대해 비교해보려고 한다.


먼저 많이 언급되는 컨테이너 서비스의 장점을 먼저 살펴보자.

- Continuous Delivery(CD): 흔히 DevOps에서 언급하는 지속적 배포 과정을 컨테이너만 구성하면 되기 때문에 쉽다.

(혹시나 배포에 실패할 경우 이전 버전의 컨테이너만 다시 roll-back하면 된다.)

- Replication/Isolation: 컨테이너만 복사하면 되기 때문에 replica를 만들기 쉽다. 또한 컨테이너가 여러 개 복사 되어도 여타 환경에 독립적이다.

- Testing: 위에서 언급했듯이 컨테이너는 독립적인 환경을 가지기 때문에 다른 환경에 영향없이 테스트를 할 수 있다.

- Scalability: 컨테이너 단위로 확장이 쉽다. 단순히 인스턴스에서 컨테이너만 추가/삭제하면 된다. 

(Orchestration Tool에 따라 조금 다르다.)

- Performance: VM과 비교했을 때 컨테이너는 가볍고 성능적으로 뛰어나다. 

(VM와 컨테이너의 구성 자체가 다르기 때문이다.)

- Availability : 실행 중인 컨테이너에 문제가 생겼을 때 쉽게 다른 컨테이너에서 작업을 대신 해 줄 수 있다.

(컨테이너 스케줄링 방법에 따라 조금 차이가 있을 수 있다.)


이러한 컨테이너 서비스는 이 전에도 사용되긴 했었지만 MSA(Micro Service Architecture)와 DevOps의 개념이 자리를 잡으면서 거의 필수적인 요소로 언급되었다. 그래서 이번 포스팅에서는 AWS에서 제공하는 컨테이버 서비스인 ECS와 최근 대세가 된 오픈 소스인 Kubernetes에 대해 비교해 보려고 한다.



 

그림 1. Kubernetes(Left), ECS(Right) Architecture


그림 1의 왼쪽을 보면 k8s(kubernetes)의 아키텍처를 확인 할 수 있다. k8s는 구글에서 만든 오픈 소스 프로젝트로 컨테이너화된 어플리케이션을 자동으로 배포, 확장, 관리 등을 위한 Orchestration framework이다. 또한 오른쪽을 보면 ECS의 아키텍처를 확인 할 수 있다. ECS는 네이밍에서도 할 수 있듯이 AWS에서 만든 Orchestration framework로 EC2 인스턴스 위에 컨테이너화된 어플리케이션을 동작시킨다. 

이 두 가지의 세부 특징을 들여다 보기전에 개략적으로 비교해보면 아래와 같다.


 

 Kubernetes

ECS 

 배포 환경

 Private/Public Cloud 및 On-premise

 AWS EC2 

 오픈 소스

 활성화된 오픈 소스

 부분적으로 오픈 소스 (크게 활성화는 안됨)

위의 테이블에서 개략적으로 설명은 해 놓았지만 하나 하나 살펴보면 차이가 날 수 밖에 없는 부분이다.

먼저 배포 환경은 k8s는 다양한 환경에서 배포 할 수 있지만 이는 오픈 소스이기 때문에 어찌보면 당연한 것이다. 현재는 메이커 3사 클라우드(AWS, Google, Azure)에서 k8s를 위한 서비스를 제공하기 때문에 ECS와 환경적인 부분은 큰 차이가 없다. 


그림 2. Popularity for K8s Vs ECS 


다음으로 오픈 소스는 애초에 시작 지점부터 다르기 때문에 그림 2에서 인기도가 큰 의미가 있을까 라는 생각이 든다. 하지만 Kubernetes는 오픈 소스로서 활발히 프로젝트가 진행되고 있기 때문에 유지 보수 및 성능 향상이 더 나을 수 있다. (물론 ECS는 AWS의 전문 조직이 있어서 더 유지 보수가 잘 될 수도 있다.)

이렇듯 k8s와 ECS의 전반적인 부분은 오픈 소스에 따라서 지표가 조금은 다르다. 그렇기 때문에 세부 특징별로 비교하는 것이 k8s와 ECS의 차이를 좀 더 확연히 아는데 도움이 될 것이다.


 

Kubernetes 

ECS 

 Application Definition

- Pod, Deployment, Service를 사용 

- Task를 사용 

 HA(High Availability)

- Deployment에 의해 Nodes에 Pod를 분산 시킴

- Health check를 통해 작동하지 않는 Pod는 삭제

- ELB에 의해 Traffic이 분산됨

- Control Plane은 AWS에 의해 관리됨

 Load Balancing

- Service가 Load balancer 역할을 하며 Pod에 Traffic을 분산 시킴

- ELB에서 CNAME을 제공

(ALB 및 Classic 사용 가능) 

 Auto-scaling

- Deployment에 의해 수동 및 자동으로 조절됨

- Resource metrics 지원

- Task Definition에 의해 수동으로 조절됨

- CloudWatch가 사용됨 (Resource metrics 확인)

 Health Check

- Liveness 및 Readiness 사용

- CloudWatch를 사용 

 Block Storage

- NFS, EBS, iSCSI 등등 지원

- EBS 지원

 Networking

- Flat network (모든 Pod는 서로 간에 통신이 가능)

- AWS VPC 지원

 Service Discovery

- 환경 변수 및 DNS 사용 

- ELB CNAME 사용

 Performance / Scalability

- 최대 5,000개의 Node까지 확장 (1.6 버전에서)

- 최대 1,000 개의 컨테이너까지 확장


위의 테이블에서 특징을 비교한 것을 보면 전반적으로 대부분의 기능을 Kubernetes와 ECS는 지원하고 있다. 때문에 서로 간에 기능 상에 큰 차이는 보여지지 않는다. (물론 언급한 특징들은 개략적인 부분을 나타낸 것이기 때문에 서로 다른 아키텍처 상에서 세밀한 동작 같은 부분은 많이 다를 수 있다.)


때문에 Kubernetes와 ECS는 사용 목적에 따라 선택이 달라 질 수 있다. 예를 들어 AWS 환경에서만 사용하고, AWS 내장 서비스와 연계하여 서비스*를 개발하고 싶다면 Kubernetes 보다는 ECS가 좀 더 낫다. 반면에 Kubernetes는 pluggable 아키텍처이기 때문에 다른 서비스 및 도구와 결합하여 사용 하고 싶다면 ECS 보다는 Kubernetes가 낫다.

* ECS에서 연계하여 사용 서비스의 비용에 대해서도 잘 파악해야 한다. (ELB, CloudWatch, Route 53 등등의 서비스가 사용 될 수 있기 때문에)


지금까지는 단순히 오픈 소스인 Kubernetes에 대해 비교해 보았다. 그렇다면 Vendor에서 지원하는 Kubernetes의 경우는 어떨지 다음 포스팅에서 알아보도록 하겠다.


https://medium.com/devopslinks/ecs-vs-eks-vs-fargate-the-good-the-bad-the-ugly-9f68bfc3bb73

https://dzone.com/articles/kubernetes-vs-amazon-ecs

https://www.stratoscale.com/blog/kubernetes/ec2-container-service-vs-kubernetes/