전체 글 (148) 썸네일형 리스트형 ECS Cluster & Container - CloudWatch Metric 수집 ECS를 구축 시 아래 옵션을 체크해주면 됩니다. ECS 구축하기 참고 이후 서비스까지 모두 띄운 후에 아래와 같은 지표들을 확인할 수 있습니다. Task의 개수, Memory 사용률, 네트워크, 스토리지 등을 확인할 수 있으며, 기본 ECS 지표에서도 CPU 및 Memory 사용률을 보실 수 있습니다. Fargate의 경우 다른 설정없이 알아서 수집되기 때문에 따로 글을 작성하지는 않겠습니다. ECS에서 Cloudwatch를 통해 메트릭을 수집하는 방법을 알아봤습니다. Cloudwatch 경보 설정 - 2. SNS, SNS SMS, SES 보내기 먼저 SNS가 발생하면 람다에 SNS가 발생한 내역을 전달하고, 이 내용에서 필요한 부분들만 수집하여서 메일을 보내도록 구성해보겠습니다. 람다 함수를 만들기전, ec2 describe와 ses 전송, sns publish에 관한 권한이 있어야 하기 때문에 Lambda Role을 하나 만들어주겠습니다. 이제 위의 롤과 아래 코드가 작성 된 람다 함수를 만들어주겠습니다. 메일은 SES를 통해 보내주고, 메세지는 SNS의 SMS를 통해 보내주겠습니다. (SES나 SMS는 기본적으로 보낼 수 있는 한도 제한이 작아 꼭 리밋을 체크하시기 바립니다.) 혹은 다른 주제를 만들어서, Email 전송이 있는 구독들을 만든 후 SNS Publish를 하셔도 됩니다. def send_email_sns(sub, content.. Cloudwatch 경보 설정 - 1. 기본 SNS를 통한 알림 Cloudwatch Alert은 Cloudwatch에서 수집 되고 있는 지표에 대해서만 설정이 가능합니다. 이를 SNS연동 혹은 Lambda와의 연동을 통해서 수집된 지표의 임계값이 설정된 값에 대한 조건을 만족하면, 알림을 받을 수 있도록 설정하는 부분입니다. 먼저 SNS부터 생성해보도록 하겠습니다. SNS는 주제, 구독의 개념으로 이루어져있습니다. 만들어진 주제에 대해서, 구독을 생성하고 이를 통해 구독되어있는 Email 주소들에 대해서 이메일을 전송하게끔 구성해보도록 하겠습니다. 기본값으로 주제를 만들겠습니다. 만들어진 주제에 대해서 구독을 생성해서 어떤 이벤트가 발생하면 구독되어있는 모두에게 SNS를 통해 알림을 보낼 수 있습니다. 메일 커스터마이징이나 SMS같은 경우는 람다에서 구성을 해야하기 .. CWAgent - 2. EC2 Windows Memory / Disk 수집 리눅스와 동일하게 IAM Role을 설정해주시고, 폴더를 하나 만들어주세요 Command + R -> CMD로 들어가셔서 아래 명령어를 수행해서 CWAgent를 설치해주세요 curl -O https://s3.amazonaws.com/amazoncloudwatch-agent/windows/amd64/latest/amazon-cloudwatch-agent.msi msiexec /i amazon-cloudwatch-agent.msi 이제 config 파일을 만들도록 하겠습니다. 꼭 저장 포맷을 ansi로 저장해주세요. 그리고 리눅스와 수집하는 매트릭 명칭이 조금 다르니 그 부분도 꼭 확인해주시기 바랍니다. { "metrics": { "append_dimensions": { "AutoScalingGroupNam.. CWAgent - 1. EC2 Amazon Linux Memory / Disk 수집 Cloudwatch에서는 메모리나 디스크 사용률에 대해서 알려주지 않기 때문에 EC2의 메모리나 디스크 사용률에 대해서 알고 싶다면, 해당 메트릭을 수집할 수 있도록 하는 Agent들을 설치해야합니다. Cloudwatch 지표를 통해 메모리 디스크를 수집하기 위해서는 CloudWatchAgentServerPolicy를 가진 Role을 EC2에 준 후, Cloudwatch Agent를 설치하고 어떠한 메트릭을 수집할지 정한 후 Agent를 실행시켜주면 됩니다. 이 과정을 하나씩 진행해보도록 하겠습니다. 먼저, IAM에서 CloudWatchAgentServerPolicy을 가진 Role을 구성해보도록 하겠습니다. 사용 서비스는 EC2를 선택해주시고 다음으로 넘어가주시면 됩니다. 그 다음에는 CloudWatc.. ECS CICD Automation - 11. ECS Canary Deployment 이전 포스트에서 말씀 드렸듯이, 블루그린 배포 스크립트에서 Deploy CLI --deployment-config-name CodeDeployDefault.OneAtATime 옵션 부분을 수정해서 마지막 Deploy Script만 다음과 같이 고치면, Canary로 할 것인지 Linear로 할 것인지 정할 수 있습니다. withAWS(credentials:"$AWS_CREDENTIALS") { sh""" aws deploy create-deployment \ --application-name AppECS-${CLUSTER_NAME}-${SERVICE_NAME} \ --deployment-config-name ECSCanary10Percent1Minutes \ --deployment-group-name D.. ECS CICD Automation - 10. ECS Linear Deployment 사실 이전 블루그린 배포 스크립트에서 Deploy CLI --deployment-config-name CodeDeployDefault.OneAtATime 옵션 부분을 수정해서 마지막 Deploy Script만 다음과 같이 고치면, Canary로 할 것인지 Linear로 할 것인지 정할 수 있습니다. withAWS(credentials:"$AWS_CREDENTIALS") { sh""" aws deploy create-deployment \ --application-name AppECS-${CLUSTER_NAME}-${SERVICE_NAME} \ --deployment-config-name CodeDeployDefault.ECSLinear10PercentEvery1Minutes \ --deployment-g.. EKS istio - 2. istio 구성 istio를 세팅하도록 하겠습니다. cd ~/environment curl -L https://git.io/getLatestIstio | sh - cd istio-* sudo mv -v bin/istioctl /usr/local/bin/ tiller 계정의 rbac를 아래 명령어를 통해 수정해주세요 kubectl apply -f install/kubernetes/helm/helm-service-account.yaml helm을 통해 istio를 설치하도록 하겠습니다. helm install install/kubernetes/helm/istio-init --name istio-init --namespace istio-system ALB를 통해 istio를 구성할 것이기 때문에 아래와 같이 수행해주세요. h.. 이전 1 ··· 8 9 10 11 12 13 14 ··· 19 다음