I am experiencing quite a strange behaviour with AWS ELB and AWS ASG.
I gave some stress for my server and AWS ASG created 2 EC2 instances to handle the load. Both instances were running on 100% CPU utilisation so AWS ASG created two more - a 3rd and a 4th instance. The thing is that now the 3rd and 4th instances run at 0% CPU utilisation and 1st and 2nd run at ~90% CPU utilisation.
data:image/s3,"s3://crabby-images/5dab2/5dab22ddbff60627a4a9517fb02fee224dca4745" alt="4th instance"
data:image/s3,"s3://crabby-images/0d35d/0d35dee4aecf7717286e806d205a07e93fca8f00" alt="3rd instance"
data:image/s3,"s3://crabby-images/951d5/951d50b437d0c67c9b598d23d9dcd2bfde9dd64a" alt="2nd instance"
data:image/s3,"s3://crabby-images/e5918/e5918a663b80749165304b22b1f3b41755e2c084" alt="1st instance"
Why the load between instances is not shared so all of them would be loaded with ~45% CPU utilisation ? Why some instances are maxed and some stay idle?
P.S. My AWS ASG scaling policy :
Execute policy when: As required to maintain Average CPU Utilization at 80
Take the action: Add or remove instances as required