Diese Dokumentation bezieht sich AWS CLI nur auf Version 1 von. Dokumentation zu Version 2 von finden Sie im Benutzerhandbuch für Version 2. AWS CLI
Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Starten, Auflisten und Schließen von EC2 Amazon-Instances in der AWS CLI
Sie können die AWS Command Line Interface (AWS CLI) verwenden, um Amazon Elastic Compute Cloud (AmazonEC2) -Instances zu starten, aufzulisten und zu beenden. Wenn Sie eine Instance starten, die nicht unter das AWS kostenlose Kontingent fällt, wird Ihnen nach dem Start der Instance eine Rechnung gestellt, und zwar für die Zeit, in der die Instance läuft, auch wenn sie inaktiv bleibt.
Anmerkung
Weitere Befehlsbeispiele finden Sie im AWS CLIAWS CLI Referenzhandbuch
Themen
Voraussetzungen
Um die ec2
-Befehle in diesem Thema auszuführen, sind folgende Schritte erforderlich:
Installieren und Konfigurieren der AWS CLI. Weitere Informationen erhalten Sie unter Installation, Aktualisierung und Deinstallation von AWS CLI und Authentifizierungs- und Zugangsdaten für AWS CLI.
-
Stellen Sie Ihre IAM Berechtigungen so ein, dass Sie Amazon EC2 Zugriff gewähren. Weitere Informationen zu IAM Berechtigungen für Amazon EC2 finden Sie unter IAMRichtlinien für Amazon EC2 im EC2Amazon-Benutzerhandbuch.
-
Erstellen Sie ein Schlüsselpaar und eine Sicherheitsgruppe.
-
Wählen Sie ein Amazon Machine Image (AMI) aus und notieren Sie sich die AMI ID. Weitere Informationen finden Sie unter Suchen eines geeigneten AMI Produkts im EC2Amazon-Benutzerhandbuch.
Starten Ihrer Instance
Verwenden Sie den aws ec2
run-instances
Befehl, um eine EC2 Amazon-Instance mit der von AMI Ihnen ausgewählten zu starten. Sie können die Instance in einer virtuellen privaten Cloud (VPC) starten.
Die Instance weist zu Beginn den Status pending
auf. Sie wechselt aber nach wenigen Minuten in den Status running
.
Das folgende Beispiel zeigt, wie eine t2.micro
Instanz im angegebenen Subnetz von a VPC gestartet wird. Ersetzen Sie das italicized
Parameterwerte durch Ihre eigenen.
$
aws ec2 run-instances --image-id
ami-xxxxxxxx
--count 1 --instance-type t2.micro --key-nameMyKeyPair
--security-group-idssg-903004f8
--subnet-idsubnet-6e7f829e
{ "OwnerId": "123456789012", "ReservationId": "r-5875ca20", "Groups": [ { "GroupName": "my-sg", "GroupId": "sg-903004f8" } ], "Instances": [ { "Monitoring": { "State": "disabled" }, "PublicDnsName": null, "Platform": "windows", "State": { "Code": 0, "Name": "pending" }, "EbsOptimized": false, "LaunchTime": "2013-07-19T02:42:39.000Z", "PrivateIpAddress": "10.0.1.114", "ProductCodes": [], "VpcId": "vpc-1a2b3c4d", "InstanceId": "i-5203422c", "ImageId": "ami-173d747e", "PrivateDnsName": "ip-10-0-1-114.ec2.internal", "KeyName": "MyKeyPair", "SecurityGroups": [ { "GroupName": "my-sg", "GroupId": "sg-903004f8" } ], "ClientToken": null, "SubnetId": "subnet-6e7f829e", "InstanceType": "t2.micro", "NetworkInterfaces": [ { "Status": "in-use", "SourceDestCheck": true, "VpcId": "vpc-1a2b3c4d", "Description": "Primary network interface", "NetworkInterfaceId": "eni-a7edb1c9", "PrivateIpAddresses": [ { "PrivateDnsName": "ip-10-0-1-114.ec2.internal", "Primary": true, "PrivateIpAddress": "10.0.1.114" } ], "PrivateDnsName": "ip-10-0-1-114.ec2.internal", "Attachment": { "Status": "attached", "DeviceIndex": 0, "DeleteOnTermination": true, "AttachmentId": "eni-attach-52193138", "AttachTime": "2013-07-19T02:42:39.000Z" }, "Groups": [ { "GroupName": "my-sg", "GroupId": "sg-903004f8" } ], "SubnetId": "subnet-6e7f829e", "OwnerId": "123456789012", "PrivateIpAddress": "10.0.1.114" } ], "SourceDestCheck": true, "Placement": { "Tenancy": "default", "GroupName": null, "AvailabilityZone": "us-west-2b" }, "Hypervisor": "xen", "BlockDeviceMappings": [ { "DeviceName": "/dev/sda1", "Ebs": { "Status": "attached", "DeleteOnTermination": true, "VolumeId": "vol-877166c8", "AttachTime": "2013-07-19T02:42:39.000Z" } } ], "Architecture": "x86_64", "StateReason": { "Message": "pending", "Code": "pending" }, "RootDeviceName": "/dev/sda1", "VirtualizationType": "hvm", "RootDeviceType": "ebs", "Tags": [ { "Value": "MyInstance", "Key": "Name" } ], "AmiLaunchIndex": 0 } ] }
Hinzufügen eines Blockgeräts zu Ihrer Instance
Jede gestartete Instance hat ein zugehöriges Root-Gerät-Volume. Sie können die Blockgerätezuweisung verwenden, um zusätzliche Amazon Elastic Block Store (AmazonEBS) -Volumes oder Instance-Speicher-Volumes anzugeben, die an eine Instance angehängt werden sollen, wenn sie gestartet wird.
Zum Hinzufügen eines Blockgeräts zu Ihrer Instance geben Sie die Option --block-device-mappings
an, wenn Sie run-instances
verwenden.
Der folgende Beispielparameter stellt ein EBS Amazon-Standardvolume mit einer Größe von 20 GB bereit und ordnet es mithilfe der Kennung Ihrer Instance zu/dev/sdf
.
--block-device-mappings "[{\"DeviceName\":\"
/dev/sdf
\",\"Ebs\":{\"VolumeSize\":20
,\"DeleteOnTermination\":false}}]"
Das folgende Beispiel fügt ein EBS Amazon-Volume hinzu, dem auf der Grundlage eines vorhandenen Snapshots zugeordnet wurde. /dev/sdf
Ein Snapshot stellt ein Image dar, das für Sie in das Volume geladen wurde. Wenn Sie einen Snapshot angeben, müssen Sie keine Volume-Größe angeben; es wird groß genug für Ihr Image sein. Wenn Sie aber einen Größenwert angeben, muss dieser größer oder gleich der Snapshot-Größe sein.
--block-device-mappings "[{\"DeviceName\":\"
/dev/sdf
\",\"Ebs\":{\"SnapshotId\":\"snap-a1b2c3d4
\"}}]"
Im folgenden Beispiel werden zwei Volumes zu Ihrer Instance hinzugefügt. Die Anzahl der Volumes, die für Ihre Instance verfügbar sind, hängt vom Instance-Typ ab.
--block-device-mappings "[{\"DeviceName\":\"
/dev/sdf
\",\"VirtualName\":\"ephemeral0
\"},{\"DeviceName\":\"/dev/sdg
\",\"VirtualName\":\"ephemeral1
\"}]"
Das folgende Beispiel erstellt das Mapping (/dev/sdj
), stellt aber kein Volume für die Instance bereit.
--block-device-mappings "[{\"DeviceName\":\"
/dev/sdj
\",\"NoDevice\":\"\"}]"
Weitere Informationen finden Sie unter Block Device Mapping im EC2Amazon-Benutzerhandbuch.
Hinzufügen eines Tags zu Ihrer Instance
Ein Tag ist eine Bezeichnung, die Sie einer AWS Ressource zuweisen. Damit können Sie Metadaten zu Ressourcen hinzufügen, die Sie für eine Vielzahl von Zwecken einsetzen können. Weitere Informationen finden Sie unter Tagging Your Resources im EC2Amazon-Benutzerhandbuch.
Das folgende Beispiel zeigt, wie Sie ein Tag mit dem Schlüsselnamen „Name
“ und den Wert „MyInstance
“ zur angegebenen Instance hinzufügen, in dem Sie den Befehl aws ec2
create-tags
verwenden.
$
aws ec2 create-tags --resources
i-5203422c
--tags Key=Name
,Value=MyInstance
Herstellen einer Verbindung zu Ihrer Instance
Wenn die Instance ausgeführt wird, können Sie eine Verbindung mit ihr herstellen und sie genau so verwenden wie einen Computer, der sich direkt vor Ihnen befindet. Weitere Informationen finden Sie unter Connect to Your Amazon EC2 Instance im EC2Amazon-Benutzerhandbuch.
Auflisten Ihrer Instances
Sie können den verwenden AWS CLI , um Ihre Instances aufzulisten und Informationen zu ihnen einzusehen. Sie können alle Ihre Instances auflisten oder die Ergebnisse auf der Grundlage der Instances, die für Sie von Interesse sind, filtern.
Die folgenden Beispiele demonstrieren die Verwendung des aws ec2
describe-instances
-Befehls.
Mit dem folgenden Befehl werden alle Ihre Instances aufgelistet.
$
aws ec2 describe-instances
Der folgende Befehl filtert die Liste nur nach Ihren t2.micro
-Instances und gibt nur die InstanceId
-Werte für die einzelnen Übereinstimmungen aus.
$
aws ec2 describe-instances --filters "Name=instance-type,Values=t2.micro" --query "Reservations[].Instances[].InstanceId"
[ "i-05e998023d9c69f9a" ]
Der folgende Befehl listet alle Ihre Instances mit dem Tag Name=MyInstance
auf.
$
aws ec2 describe-instances --filters "Name=tag:
Name
,Values=MyInstance
"
Der folgende Befehl listet Ihre Instances auf, die mit einer der folgenden Methoden gestartet wurdenAMIs: ami-x0123456
ami-y0123456
, undami-z0123456
.
$
aws ec2 describe-instances --filters "Name=image-id,Values=
ami-x0123456
,ami-y0123456
,ami-z0123456
"
Beenden Ihrer Instance
Das Beenden einer Instance löscht diese. Sie können mit einer Instance keine Verbindung mehr herstellen, nachdem Sie sie beendet haben.
Sobald der Status der Instance zu shutting-down
oder terminated
wechselt, fallen für diese Instance keine Gebühren mehr an. Wenn Sie später eine erneute Verbindung zu einer Instance herstellen möchten, verwenden Sie stop-instances statt terminate-instances
. Weitere Informationen finden Sie unter Terminate Your Instance im EC2Amazon-Benutzerhandbuch.
Zum Löschen einer Instance verwenden Sie den Befehl aws ec2
terminate-instances
.
$
aws ec2 terminate-instances --instance-ids
i-5203422c
{ "TerminatingInstances": [ { "InstanceId": "i-5203422c", "CurrentState": { "Code": 32, "Name": "shutting-down" }, "PreviousState": { "Code": 16, "Name": "running" } } ] }
Referenzen
AWS CLI Referenz:
Andere Referenz:
-
AWS CLI Codebeispiele und Beiträge dazu AWS SDK finden Sie im AWS Codebeispiel-Repository
unter GitHub.