안녕하세요~!
오늘은 베스핀글로벌 D&A실 김한종님이 작성해 주신 AWS 인스턴스 시작&중지(Lambda&EventBridge) 구축 가이드에 대해서 알아보겠습니다 🙂
1. 인스턴스 스케줄러 아키텍쳐
data:image/s3,"s3://crabby-images/fff84/fff84d18c91cc2265c5cf17970f321cba33b47a8" alt=""
2-1. 람다가사용할 IAM Role & Policy 설정
data:image/s3,"s3://crabby-images/f4f01/f4f01e1b80f33904463715d3f12eb941a7763983" alt=""
Lambda 에 적용할 정책 생성
2-2. 람다가사용할 IAM Role & Policy 설정
data:image/s3,"s3://crabby-images/c9de8/c9de82108df63a1d30bdfb6e857da2ac56b0b784" alt=""
1. JSON 선택
2. 권한 기재
{
“Version”: “2012-10-17”,
“Statement”: [
{
“Sid”: “VisualEditor0”,
“Effect”: “Allow”,
“Action”: [
“ec2:Describe*”,
“ec2:Start*”,
“ec2:Stop*”,
“rds:StartDBCluster”,
“rds:StopDBCluster”,
“rds:ListTagsForResource”,
“rds:DescribeDBInstances”,
“rds:StopDBInstance”,
“rds:DescribeDBClusters”,
“rds:StartDBInstance”
],
“Resource”: “*”
}
] }
2-3. 람다가사용할 IAM Role & Policy 설정
data:image/s3,"s3://crabby-images/60fc1/60fc161345d8541e43f4a0ecba3e520135fb4947" alt=""
1. Role 이름 및 설명 기재
2. 정책 생성
2-4. 람다가사용할 IAM Role & Policy 설정
data:image/s3,"s3://crabby-images/eea49/eea493734e5c58b6d44bd91a3ee21ddd8ca0b58d" alt=""
Lambda 에 적용할 역할 생성
2-5. 람다가사용할 IAM Role & Policy 설정
data:image/s3,"s3://crabby-images/3fdb4/3fdb430738ae98ad852150cfff841a5e1c19ee02" alt=""
1. AWS 서비스 선택
2. Lambda 선택
2-6. 람다가사용할 IAM Role & Policy 설정
data:image/s3,"s3://crabby-images/cb10b/cb10b7f7bc47db6c39ca3a2c8de7c6bd4281b168" alt=""
미리 생성한 ec2-start-stop-role 선택
data:image/s3,"s3://crabby-images/542dd/542dd737935b9bd24e37f3adcffcce51a4973732" alt=""
Lambda 에 적용할 Policy 이름 기재
3-1. 람다 함수 생성(Start Instance)
data:image/s3,"s3://crabby-images/befe2/befe2cccb06d46d9a9aa991bd932a7a0ca583595" alt=""
Lambda 에 적용할 역할 생성
3-2. 람다함수생성(Start Instance)
data:image/s3,"s3://crabby-images/8de07/8de07f2c3f2011ef14a4718b386435acadafd476" alt=""
1. 함수 이름 : start-ec2-instance
2. 런타임 : Python 3.8
3. 기존 역할 : ec2-start-stop-lambda-policy
3-3. 람다함수생성(Start Instance)
data:image/s3,"s3://crabby-images/f62c7/f62c72622b7fc2fa99d6588f15668eb9b5aab86a" alt=""
1. EC2 Start 코드 작성
2. Region, Key 값, Value 값 설정
import boto3
region = ‘ap-northeast-2’
instances = []
ec2_r = boto3.resource(‘ec2’)
ec2 = boto3.client(‘ec2’, region_name=region)
for instance in ec2_r.instances.all():
for tag in instance.tags:
if tag[‘Key’] == ‘auto-start’:
if tag[‘Value’] == ‘true’:
instances.append(instance.id)
def lambda_handler(event, context):
ec2.start_instances(InstanceIds=instances)
print(‘started your instances: ‘ + str(instances))
3-4. 람다함수생성(Start Instance/RDS 포함)
import boto3
instances = []
ec2 = boto3.resource(‘ec2’)
ec2_c = boto3.client(‘ec2’)
rds = boto3.client(‘rds’)
def lambda_handler(event, context):
#Start EC2 Instances
for instance in ec2.instances.all():
for tag in instance.tags:
if (tag[‘Key’] == ‘auto-start’ and tag[‘Value’] == ‘true’ and instance.state[‘Name’] == ‘stopped’):
instances.append(instance.id)
print(instances)
ec2_c.start_instances(InstanceIds=instances)
print(‘stopped your instances: ‘ + str(instances))
elif (tag[‘Key’] == ‘auto-start’ and tag[‘Value’] == ‘true’ and instance.state[‘Name’] == ‘running’):
print(‘All instances are started.’)
#Start DB Instances
dbs = rds.describe_db_instances()
for db in dbs[‘DBInstances’]:
#Check if DB instance stopped. Start it if eligible.
if (db[‘DBInstanceStatus’] == ‘stopped’):
doNotStart=1
try:
GetTags=rds.list_tags_for_resource(ResourceName=db[‘DBInstanceArn’])[‘TagList’]
for tags in GetTags:
#if tag “autostart=yes” is set for instance, start it
if(tags[‘Key’] == ‘auto-start’ and tags[‘Value’] == ‘true’):
result = rds.start_db_instance(DBInstanceIdentifier=db[‘DBInstanceIdentifier’])
print (“Starting instance: {0}.”.format(db[‘DBInstanceIdentifier’]))
if(doNotStart == 1):
doNotStart=1
except Exception as e:
print (“Cannot start instance {0}.”.format(db[‘DBInstanceIdentifier’]))
print(e)
else:
print(‘All RDS instances are started.’)
** 위 코드는 EC2 및 RDS 의 현재 상태(stopped/running) 를 파악하여 stopped 상태인 인스턴스만 구동시키는 코드입니다.
3-5. 람다함수생성(Start Instance)
data:image/s3,"s3://crabby-images/44ede/44ede0e457e702c3db16a2da83e88b80ea355290" alt=""
Lambda 가동 시간 변경 시 편집하여 수동으로 수정
3-6. 람다함수생성(Start Instance)
data:image/s3,"s3://crabby-images/41ad5/41ad5766d61f9b1fcc902b55a8c37ca469eb6b63" alt=""
기본으로 3초로 되어있어 30초로 수정
data:image/s3,"s3://crabby-images/ec59e/ec59e6efc9052d74ccbdbbc610f00e455c09578e" alt=""
1. 기본 정보와 권한은 Start Instance 의 설정과 동일 하게 작성
2. EC2 Stop 코드 작성
3. Region, Key 값, Value 값 설정
import boto3
region = ‘ap-northeast-2’
instances = []
ec2_r = boto3.resource(‘ec2’)
ec2 = boto3.client(‘ec2’, region_name=region)
for instance in ec2_r.instances.all():
for tag in instance.tags:
if tag[‘Key’] == ‘auto-stop’:
if tag[‘Value’] == ‘true’:
instances.append(instance.id)
def lambda_handler(event, context):
ec2.stop_instances(InstanceIds=instances)
print(‘stopped your instances: ‘ + str(instances))
3-7. 람다함수생성(Stop Instance/RDS 포함)
import boto3
instances = []
ec2 = boto3.resource(‘ec2’)
ec2_c = boto3.client(‘ec2’)
rds = boto3.client(‘rds’)
def lambda_handler(event, context):
#Stop EC2 Instances
for instance in ec2.instances.all():
for tag in instance.tags:
if (tag[‘Key’] == ‘auto-stop’ and tag[‘Value’] == ‘true’ and instance.state[‘Name’] == ‘running’):
instances.append(instance.id)
print(instances)
ec2_c.stop_instances(InstanceIds=instances)
print(‘stopped your instances: ‘ + str(instances))
elif (tag[‘Key’] == ‘auto-stop’ and tag[‘Value’] == ‘true’ and instance.state[‘Name’] == ‘stopped’):
print(‘All instances are stopped.’)
#Stop DB instances
dbs = rds.describe_db_instances()
for db in dbs[‘DBInstances’]:
#Check if DB instance is not already stopped
if (db[‘DBInstanceStatus’] == ‘available’):
DoNotStop=1
try:
GetTags=rds.list_tags_for_resource(ResourceName=db[‘DBInstanceArn’])[‘TagList’]
for tags in GetTags:
#if tag “autostop=yes” is set for instance, stop it
if(tags[‘Key’] == ‘auto-stop’ and tags[‘Value’] == ‘true’):
result = rds.stop_db_instance(DBInstanceIdentifier=db[‘DBInstanceIdentifier’])
print (“Stopping instance: {0}.”.format(db[‘DBInstanceIdentifier’]))
if(DoNotStop == 1):
DoNotStop=1
except Exception as e:
print (“Cannot stop instance {0}.”.format(db[‘DBInstanceIdentifier’]))
print(e)
else:
print(‘All RDS instances are stopped.’)
** 위 코드는 EC2 및 RDS 의 현재 상태(stopped/running) 를 파악하여 running 또는 available상태인 인스턴스만 구동시키는 코드입니다.
4. EC2 태그지정
data:image/s3,"s3://crabby-images/8b734/8b7348a14d06127faeacc30ff431e0c1821da860" alt=""
1. EC2 에 2개의 태그 기재
2. auto-start : true 는 서버 부팅
3. auto-stop : true 는 서버 정지
5. Lambda 함수 정상 가동테스트
1. auto-start, auto-stop 함수에서 Test 클릭 시 서버 시작/정지 확인 이 가능
2. Test 처음 클릭 시 이벤트 이름만 추가하면 테스트 가능
6-1. Event Bridge(Start Event)
data:image/s3,"s3://crabby-images/ed9cc/ed9ccc7e3f9f73189f4fca5b19a42acc7819ca44" alt=""
Event Bridge 에서 규칙 생성
6-2. Event Bridge(Start Event)
data:image/s3,"s3://crabby-images/f76aa/f76aad59551794e7bae8182d35c361f42ae837b1" alt=""
1. 규칙 이름 생성
2. 일정 선택
3. Cron 식 이로 일정 선택
https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html
4. 현재 시간대(GMT) 로 변경 하여 시간 확인
6-3. Event Bridge(Start Event)
data:image/s3,"s3://crabby-images/0aea7/0aea797e82b0fac9e3bcefb0420c471ef201369c" alt=""
1. 대상 에 Lambda 함수 선택
2. Lambda 함수 선택 – start-ec2-instance
6-4. Event Bridge(Stop Event)
data:image/s3,"s3://crabby-images/20100/2010098fb1169cde8306a72fb807899ef6aa4193" alt=""
1. 규칙 이름 생성
2. 일정 선택
3. Cron 식 이로 일정 선택
4. 현재 시간대(GMT) 로 변경 하여 시간 확인
6-5. Event Bridge(Stop Event)
data:image/s3,"s3://crabby-images/03896/038965df89bee69d2fed8e5bf05395955da92170" alt=""
1. 대상 에 Lambda 함수 선택
2. Lambda 함수 선택
– stop-ec2-instance
6-6. Event Bridge(Start / Stop Event)
data:image/s3,"s3://crabby-images/5a7ad/5a7adc78c419b4b5637201751c860a656356da94" alt=""
Event Bridge 에 Start / Stop 2개의 규칙 생성 확인
감사합니다:)
data:image/s3,"s3://crabby-images/ed0c5/ed0c5eea8c92f0260face1ec79cbda65741e1d73" alt=""
문의: info@bespinglobal.com | 대표번호: 02-1688-1280