# create the nginx deployment with 2 replicas
kubectl apply -f ./my-nginx.yaml
1. EKS(Elastic Kubernetes Service)란
EKS(Elastic Kubernetes Service)는 AWS에서 Kubernetes를 실행하는 데 사용할 수 있는 Managed 서비스입니다.
EKS는 2가지 방법으로 클러스터를 생성할 때 사용할 수 있습니다.
eksctl : EKS에서 클러스터를 생성하고 관리하기위한 간단한 CLI 도구로 Weaveworks가 제공하는 공식 AWS CloudFormation 템플릿 기반으로 작동하여 단 하나의 명령으로 몇 분 만에 기본 클러스터를 만들 수 있습니다.
AWS 콘솔 및 AWS CLI : Amazon EKS 클러스터에 필요한 각 리소스를 수동으로 생성합니다.
eksctl을 활용하여 간단히 EKS 클러스터를 구성해보고, 애플리케이션을 배포해보도록 하겠습니다.
2. EKS 시작하기
Task1. 환경 구성하기
시작하기 앞서 eksctl을 사용하기 위해서는 다음과 같은 Tool을 설치하여 합니다.
해당 설치 트랙은 Linux기반으로 진행되오니 Window10 환경의 유저분들은 아래 링크를 참조하시어 Linux환경을 설치하시 바랍니다. https://jjnomad.tistory.com/2
또는, Cloud9 AWS WEB IDE를 활용할 수도 있습니다. 콘솔에서 Cloud9 확인 할 수 있습니다.
3. EKS 클러스터 생성하기
클러스터 생성하기 전 인스턴스에 접근하기 위한 키를 생성합니다. 해당 키를 통해 향후 인스턴스 ssh접근 시 활용하게 됩니다.
퍼블릭 key생성을 위해 ssh-keygen을 입력하고, 파일이름을 eks-demo로 정하겠습니다. 그리고 enter를 두번 칩니다.
아래와 같이 결과가 나오는 것을 확인 할 수 있습니다.
ls 명령어로 생성된 파일을 확인 합니다. 그럼 .pub으로 끝나는 공개키와, 비밀키를 확인 할 수 있습니다.
이제 아래코드를 실행하면 EKS 클러스터가 생성해보도록 하겠습니다.
eksctl create cluster \
--name my-cluster \
--version 1.18 \
--region us-west-2 \
--nodegroup-name linux-nodes \
--nodes 1 \
--nodes-min 1 \
--nodes-max 1 \
--ssh-access \
--ssh-public-key eks-demo.pub \
--managed \
--node-type t3.medium
eksctl은 flags를 활용하여 옵션값을 지정할 수 있습니다. 지정된 옵션은 다음과 같습니다.
- 클러스터이름 : my-cluster
- 쿠버네티스버전 : 1.18
- 리전 : us-west-2 미국서부(오레곤)
- 노드그룹이름 : linux-nodes
- node 개수 : 1
- 최소개수 : 1, 최대개수 1
- 노드타입 : t3.medium
- ssh-public-key : 방금전 생성한 퍼블릭키를 사용합니다.
4. CloudFormation 살펴보기
eksctl을 사용하면 CloudFormation에서 클러스터 생성에 필요한 여러 자원들을 자동으로 설치하여 줍니다.
생성되는데는 약 15분정도 소요 됩니다.
생성결과를 확인해보면 .kube/config에 kubeconfig 정보가 있습니다. 이정보로 만들어진 클러스터에 kubectl cli로 명령어를 처리할 수 있습니다.
노드가 잘 생성되었는지 확인해보겠습니다. kubectl get nodes
5. EKS 살펴보기
콘솔을 통해 생성된 클러스터의 정보들을 확인해보겠습니다.
클러스터 정보 확인
노드 그룹 확인
노드그룹 상세정보에서 인스턴스 유형, Auto Scling그룹, 노드의 크기, 서브넷 구성 등을 확인할 수 있습니다.
6. Nginx 배포하기
웹 서버 배포로 구성된 인프라환경을 테스트 해보겠습니다.
Task1. 배포 Deployment 파일 만들기
Pod에 ngnix를 만들 수 있는 yaml을 생성합니다.
cat <<EoF > my-nginx.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-nginx
spec:
selector:
matchLabels:
run: my-nginx
replicas: 2
template:
metadata:
labels:
run: my-nginx
spec:
containers:
- name: my-nginx
image: nginx
ports:
- containerPort: 80
EoF
해당 파일은 기 생성된 EKS 클러스터에 배포합니다.
deployment.apps/my-nginx created 결과를 확인되면, 정상적으로 만들어진 상태입니다.
Task2. Pod 생성 결과 확인하기
kubectl get pods -o wide 입력하여 생성된 Pod의 결과를 확인 하겠습니다.
Task3. 서비스 외부 노출하기
현재 외부로 노출된 상태가 아니기 때문에 접근이 불가능 합니다. 이제 외부로 노출하는 작업을 수행하겠습니다.
kubectl expose deployment/my-nginx \
--port=80 --target-port=80 \
--name=my-nginx-service \
--type=LoadBalancer
service/my-nginx-service exposed 결과가 확인되면 외부 노출이 된 상태입니다.
생성된 웹서버를 확인할 수 있습니다.
Task4. 클러스터 삭제하기
지금까지 만든 클러스터를 삭제합니다.
# 배포한 서비스를 삭제합니다.
kubectl delete svc my-nginx-service
# 생성한 클러스터를 삭제합니다.
eksctl delete cluster --name my-cluster -r us-west-2
CloudFormation에서 작업결과를 확인하실 수 있습니다.
Reference
- https://docs.aws.amazon.com/ko_kr/eks/latest/userguide/getting-started.html
- https://www.eksworkshop.com/010_introduction/
'AWS' 카테고리의 다른 글
Amazon S3 버킷으로 이미지 서버 만들기 (0) | 2021.08.07 |
---|---|
[AWS] EC2 인스턴스 SSH 접속하기(2) (0) | 2021.08.03 |
[AWS] EC2 인스턴스 SSH 접속하기(1) (0) | 2021.08.03 |
AWS 람다(Lambda)로 Python함수 구현하기 (0) | 2021.07.30 |
AWS Lambda 함수 배포하기 - Hello World (0) | 2021.07.25 |