Ya, Anda dapat melakukannya menggunakan AWS Lambda. Anda dapat memilih pemicu di Cloudwatch yang berjalan pada ekspresi Cron pada UTC.
Ini adalah tautan terkait https://aws.amazon.com/premiumsupport/knowledge-center/start-stop-lambda-cloudwatch/
Alternatif lain adalah dengan menggunakan awscli
yang tersedia dari pip
, apt-get
, yum
atau brew
, dan kemudian berjalan aws configure
dengan mandat Anda yang diekspor dari IAM dan mengeksekusi skrip bash berikut, untuk menghentikan EC2 yang telah ditandai dengan Name: Appname
dan Value: Appname Prod
. Anda dapat menggunakan awscli
untuk menandai instans Anda atau menandainya secara manual dari konsol AWS. aws ec2 stop-instances
akan menghentikan instance dan jq
digunakan untuk memfilter kueri json dan mengambil id instance yang benar menggunakan tag dari aws ec2 describe-instances
.
Untuk memverifikasi bahwa aws configure
berhasil dan mengembalikan keluaran json yang dijalankan aws ec2 describe-instances
dan id instance yang sedang berjalan harus ada di keluaran. Berikut adalah contoh keluarannya
{
"Reservations": [
{
"Instances": [
{
"Monitoring": {
"State": "disabled"
},
"PublicDnsName": "ec2-xxx.ap-south-1.compute.amazonaws.com",
"State": {
"Code": xx,
"Name": "running"
},
"EbsOptimized": false,
"LaunchTime": "20xx-xx-xxTxx:16:xx.000Z",
"PublicIpAddress": "xx.127.24.xxx",
"PrivateIpAddress": "xxx.31.3.xxx",
"ProductCodes": [],
"VpcId": "vpc-aaxxxxx",
"StateTransitionReason": "",
"InstanceId": "i-xxxxxxxx",
"ImageId": "ami-xxxxxxx",
"PrivateDnsName": "ip-xxxx.ap-south-1.compute.internal",
"KeyName": "node",
"SecurityGroups": [
{
"GroupName": "xxxxxx",
"GroupId": "sg-xxxx"
}
],
"ClientToken": "",
"SubnetId": "subnet-xxxx",
"InstanceType": "t2.xxxxx",
"NetworkInterfaces": [
{
"Status": "in-use",
"MacAddress": "0x:xx:xx:xx:xx:xx",
"SourceDestCheck": true,
"VpcId": "vpc-xxxxxx",
"Description": "",
"NetworkInterfaceId": "eni-xxxx",
"PrivateIpAddresses": [
{
"PrivateDnsName": "ip-xx.ap-south-1.compute.internal",
"PrivateIpAddress": "xx.31.3.xxx",
"Primary": true,
"Association": {
"PublicIp": "xx.127.24.xxx",
"PublicDnsName": "ec2-xx.ap-south-1.compute.amazonaws.com",
"IpOwnerId": "xxxxx"
}
}
],
"PrivateDnsName": "ip-xxx-31-3-xxx.ap-south-1.compute.internal",
"Attachment": {
"Status": "attached",
"DeviceIndex": 0,
"DeleteOnTermination": true,
"AttachmentId": "xxx",
"AttachTime": "20xx-xx-30Txx:16:xx.000Z"
},
"Groups": [
{
"GroupName": "xxxx",
"GroupId": "sg-xxxxx"
}
],
"Ipv6Addresses": [],
"OwnerId": "xxxx",
"PrivateIpAddress": "xx.xx.xx.xxx",
"SubnetId": "subnet-xx",
"Association": {
"PublicIp": "xx.xx.xx.xxx",
"PublicDnsName": "ec2-xx.ap-south-1.compute.amazonaws.com",
"IpOwnerId": "xxxx"
}
}
],
"SourceDestCheck": true,
"Placement": {
"Tenancy": "default",
"GroupName": "",
"AvailabilityZone": "xx"
},
"Hypervisor": "xxx",
"BlockDeviceMappings": [
{
"DeviceName": "/dev/xxx",
"Ebs": {
"Status": "attached",
"DeleteOnTermination": true,
"VolumeId": "vol-xxx",
"AttachTime": "20xxx-xx-xxTxx:16:xx.000Z"
}
}
],
"Architecture": "x86_64",
"RootDeviceType": "ebs",
"RootDeviceName": "/dev/xxx",
"VirtualizationType": "xxx",
"Tags": [
{
"Value": "xxxx centxx",
"Key": "Name"
}
],
"AmiLaunchIndex": 0
}
],
"ReservationId": "r-xxxx",
"Groups": [],
"OwnerId": "xxxxx"
}
]
}
The bash script berikut ini stop-ec2.sh
di /home/centos/cron-scripts/
mana terinspirasi dari SO posting ini
(instance=$(aws ec2 describe-instances | jq '.Reservations[].Instances | select(.[].Tags[].Value | startswith("Appname Prod") ) | select(.[].Tags[].Key == "Appname") | {InstanceId: .[].InstanceId, PublicDnsName: .[].PublicDnsName, State: .[].State, LaunchTime: .[].LaunchTime, Tags: .[].Tags} | [.]' | jq -r .[].InstanceId) && aws ec2 stop-instances --instance-ids ${instance} )
Jalankan file menggunakan sh /home/centos/cron-scripts/stop-ec2.sh
dan verifikasi bahwa instans EC2 dihentikan. Untuk men-debug, jalankan aws ec2 describe-instances | jq '.Reservations[].Instances | select(.[].Tags[].Value | startswith("Appname Prod") ) | select(.[].Tags[].Key == "Appname") | {InstanceId: .[].InstanceId, PublicDnsName: .[].PublicDnsName, State: .[].State, LaunchTime: .[].LaunchTime, Tags: .[].Tags} | [.]' | jq -r .[].InstanceId
dan lihat apakah itu mengembalikan ID instance yang benar yang telah diberi tag.
Kemudian di crontab -e
baris berikut dapat ditambahkan
30 14 * * * sh /home/centos/cron-scripts/stop-ec2.sh >> /tmp/stop
yang akan mencatat keluaran ke /tmp/stop
. Ini 30 14 * * *
adalah ekspresi cron UTC yang dapat Anda periksa https://crontab.guru/
. Demikian pula, mengganti dengan aws ec2 start-instances
dapat memulai sebuah instance.