Zend_Service_Amazon_Ec2: Instanzen
Instanz Typen
Amazon EC2 Instanzen werden in zwei Familien gruppiert: Standard und High-CPU. Standard
Instanzen haben Speicher und CPU Ratio die für die meisten generell
gedachten Anwendungen passen; High-CPU Instanzen haben proportional mehr
CPU Ressourcen als Speicher (RAM) und sind gedacht für
rechen-intensive Anwendungen. Wenn Instanz-Typen ausgewählt werden, kann es gewünscht
sein wenig intensive Instanztypen für Web-Server Instanzen zu verwenden und intensivere
Instanz-Typen für eigene Datenbank-Instanzen. Zusätzlich kann es gewünscht sein
CPU Instanztypen für CPU-intensive
Datenverarbeitungs Tasks zu verwenden.
Eine der Vorteile von EC2 ist das man pro Stunde der Instanz zahlt, was es bequem und
kostengünstig macht die Performance der eigenen Anwendung auf verschiedenen
Instanzfamilien und Typen zu testen. Ein guter Weg um zu erkennen welches die
passenste Instanzfamilie und der passenste Instanztyp ist, besteht darin Testinstanzen
zu starten und die Anweundung zu benchmarken.
Instanz Typen
Der Instanztyp ist als Konstante im Code definiert. Spalte acht in der Tabelle ist
der definierte Name der Konstante
Vorhandene Instanztypen
Typ
CPU
Hauptspeicher
Plattenspeicher
Plattform
I/O
Name
Name der Konstante
Klein
1 EC2 Recheneinheit (1 virtueller Kern mit 1
EC2 Recheneinheit)
1.7 GB
160 GB Speicher der Instanz (150 GB plus 10 GB Root Partition)
32-bit
Moderat
m1.small
Zend_Service_Amazon_Ec2_Instance::SMALL
Groß
4 EC2 Recheneinheiten (2 virtuelle Kerne mit
jeweils 2 EC2 Recheneinheiten)
7.5 GB
850 GB Speicher der Instanz (2 x 420 GB plus 10 GB Root Partition)
64-bit
Hoch
m1.large
Zend_Service_Amazon_Ec2_Instance::LARGE
Extra Groß
8 EC2 Recheneinheiten (4 virtuelle Kerne mit
jeweils 2 EC2 Recheneinheiten)
15 GB
1,690 GB Speicher der Instanz (4 x 420 GB plus 10 GB Root Partition)
64-bit
Hoch
m1.xlarge
Zend_Service_Amazon_Ec2_Instance::XLARGE
High-CPU Medium
5 EC2 Recheneinheiten (2 virtuelle Kerne mit
jeweils 2.5 EC2 Recheneinheiten)
1.7 GB
350 GB Speicher der Instanz (340 GB plus 10 GB Root Partition)
32-bit
Durchschnittlich
c1.medium
Zend_Service_Amazon_Ec2_Instance::HCPU_MEDIUM
High-CPU Extra Groß
20 EC2 Recheneinheiten (8 virtuelle Kerne mit
jeweils 2.5 EC2 Recheneinheiten)
7 GB
1,690 GB Speicher der Instanz (4 x 420 GB plus 10 GB Root Partition)
64-bit
Hoch
c1.xlarge
Zend_Service_Amazon_Ec2_Instance::HCPU_XLARGE
Ausführen von Amazon EC2 Instanzen
Dieses Kapitel beschreibt die Methoden für die Behandlung von Amazon EC2 Instanzen.
Starten neuer EC2 Instanzen
run startetn eine spezifische Anzahl von EC2 Instanzen.
run nimmt für den Start ein Array von Parametern. Anbei ist eine
Tabelle welche die gültigen Werte enthält.
Gültige Optionen für das Starten
Name
Beschreibung
Benötigt
imageId
ID der AMI mit der Instanzen gestartet
werden.
Ja
minCount
Minimale Anzahl der zu startenden Instanzen. Standardwert: 1
Nein
maxCount
Maximale Anzahl der zu startenden Instanzen. Standardwert: 1
Nein
keyName
Name des Schlüsselpaares mit dem Instanzen gestartet werden.
Wenn man keinen Schlüssel angibt, werden alle Instanzen
unangreifbar.
Nein
securityGroup
Name der Sicherheitsgruppe mit der Instanzen zu assoziieren
sind.
Nein
userData
Die Benutzerdaten welche bei den zu startenden Instanzen
vorhanden sind. Diese sollten nicht Base64 verschlüsselt
sein.
Nein
instanceType
Spezifiziert den Instanztyp. Standardwert: m1.small
Nein
placement
Spezifiziert die Availability Zone in der Instanz(en) zu
starten sind. Standardmäßig wählt Amazon
EC2 eine Availability Zone aus.
Nein
kernelId
Die ID des Kernels mit dem die Instanz gestartet werden
soll.
Nein
ramdiskId
Die ID der RAM Disk mit der die Instanz
gestartet werden soll.
Nein
blockDeviceVirtualName
Spezifiziert den virtuellen Name der zu dem
korrespondierenden Devicenamen gemappt werden soll. Zum
Beispiel: instancestore0
Nein
blockDeviceName
Spezifiziert das Device zu dem der virtuelle Name gemappt
werden soll. Zum Beispiel: sdb
Nein
monitor
Schaltet das Monitoring für die AWS
CloudWatch Instanz ein
Nein
run gibt Informationen über jede Instanz zurück die gestartet wird.
run(array('imageId' => 'ami-509320',
'keyName' => 'myKey',
'securityGroup' => array('web',
'default')));
]]>
Neu booten von EC2 Instanzen
reboot bootet eine oder mehrere Instanzen.
Diese Operation ist asynchron; die queuet nur die Anfrage eine spezifizierte
Instanz(en) zu rebooten. Die Operation wird erfolgreich sein wenn die Instanzen
gültig sind und dem Benutzer gehören. Anfragen um beendete Instanzen zu rebooten
werden ignoriert.
reboot gibt ein boolsches TRUE oder
FALSE zurück
reboot('instanceId');
]]>
Beenden von EC2 Instanzen
terminate führt eine oder mehrere Instanzen herunter. Diese Operation
ist idempotent; wenn eine Instanz mehr als einmal terminiert wird, wird jeder
Aufruf erfolgreich sein.
terminate gibt ein boolsches TRUE oder
FALSE zurück
terminate('instanceId');
]]>
Terminierte Instanzen
Terminierte Instanzen bleiben nach der Terminierung sichtbar (voraussichtlich
eine Stunde).
Utilities für Amazon Instanzen
In diesem Kapitel erfährt man wie man Informationen über die Ausgabe der Console
erhält und sieht ob eine Instanz einen Produktcode enthält.
Instanzen beschreiben
describe gibt Information über die Instanzen zurück die einem
gehören.
Wenn man eine oder mehrere Instanz IDs spezifiziert, gibt Amazon EC2 Informationen
über diese Instanzen zurück. Wenn man keine Instanz IDs spezifiziert, gibt Amazon
EC2 Informationen über alle relevanten Instanzen zurück. Wenn eine ungültige
Instanz ID spezifiziert wird, wird ein Fehler zurückgegeben. Wenn eine Instanz
spezifiziert wird die man nicht besitzt, wird diese in den zurückgegebenen
Ergebnissen nicht enthalten sein.
describe gibt ein Array zurück das Informationen über die Instanz
enthält.
describe('instanceId');
]]>
Beendete Instanzen
Kürzlich beendete Instanzen können in den zurückgegebenen Ergebnissen
vorkommen. Das Interval ist normalerweise weniger als eine Stunde. Wenn man
nicht will das beendete Instanzen zurückgegeben werden, muß eine zweite
Variable, ein boolsches TRUE, an describe
übergeben werden, und die beendete Instanz wird ignoriert.
Instanzen anhand der Image Id beschreiben
describeByImageId ist funktional identisch mit describe
gibt aber nur die Instanz zurück, welche die angegebene imageId verwendet.
describeByImageId gibt ein Array zurück das Informationen über die
Instanzen enthält, die von der übergebenen imageId gestartet wurden.
describeByImageId('imageId');
]]>
Beendete Instanzen
Kürzlich beendete Instanzen können in den zurückgegebenen Ergebnissen
vorkommen. Das Interval ist normalerweise weniger als eine Stunde. Wenn man
nicht will das beendete Instanzen zurückgegeben werden, muß eine zweite
Variable, ein boolsches TRUE, an describe
übergeben werden, und die beendete Instanz wird ignoriert.
Empfangen von Konsolen-Ausgaben
consoleOutput empfänge die Ausgabe der Konsole für eine spezifizierte
Instanz.
Die Ausgabe der Konsole einer Instanz wird gepuffert und kurz nach dem Booten, neu
Booten, und Beenden der Instanz gesendet. Amazon EC2 sichert die letzten 64 KB
Ausgabe, welche zumindest eine Stunde nach dem letzten Senden verfügbar sein ist.
consoleOutput gibt ein Array zurück das
instanceId, timestamp von der letzten Ausgabe enthält und
output von der Konsole.
consoleOutput('instanceId');
]]>
Produktcode an einer Instanz bestätigen
confirmProduct gibt TRUE zurück wenn der
spezifizierte Produktcode der spezifizierten Instanz angehängt ist. Die Operation
gibt FALSE zurück wenn der Produktcode der Instanz nicht
angehängt ist.
Die confirmProduct Operation kann nur von dem Eigentümer der
AMI ausgeführt werden. Dieses Feature ist nützlich wenn ein
AMI Eigentümer Support anbietet und sicherstellen will ob die
Instanz eines Benutzer korrekt ist.
confirmProduct('productCode', 'instanceId');
]]>
Einschalten des CloudWatch Monitorings für Instanzen
monitor gibt die Liste von Instanzn und deren aktuellen Status vom
CloudWatch Monitorings zurück. Wenn die Instant das Monitoring aktuell nicht
aktiviert hat, dann wird es eingeschaltet.
monitor('instanceId');
]]>
Ausschalten des CloudWatch Monitorings für Instanzen
monitor gibt die Liste von Instanzn und deren aktuellen Status vom
CloudWatch Monitorings zurück. Wenn die Instant das Monitoring aktuell aktiviert
hat, dann wird es ausgeschaltet.
unmonitor('instanceId');
]]>