3

I've been given a task where I have to utilize about 200 EC2 instances in AWS. Since I'm completely new to AWS, I'm having trouble doing basic stuff.

Each instance is a Ubuntu and they all have the same 4 key softwares installed on them.

I have to be able to control all 200 instances, like starting the same command on every instance, and other similar bulk tasks.

Specifically:

  • Stop all currently running instances.
  • Start all currently stopped instances.
  • Pull a configuration file from the main server.
  • Start certain application (all start app1, app3)

As far as I understood from the starting guides, I have to install AWS CLI which I did. (I'm on a Mac btw). However, I still don't understand how to do the things described from this command line.

TLDR: How do I execute/run commands simultaneously on every running EC2 instance from CLI?

1
  • 1
    Stop and Start you can do from the AWS CLI with a for loop or xargs from the describe-instances command Commented Feb 15, 2014 at 15:02

2 Answers 2

8

ClusterSSH, Capistrano, pconsole, and many other tools exist to execute commands across many Linux servers. In addition, you might look into configuration management tools like Puppet, Chef, SaltStack, or Ansible in terms of orchestrating your entire environment.

Generally, the AWS command line interface is for interfacing with the product and services (spinning up instances, taking images, etc), not controlling individual VMs at the console level.

1

Amazon has announced a "Run Command" feature.

1
  • this is very limited, you cannot run your own commands Commented Apr 20, 2017 at 8:07

You must log in to answer this question.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.