Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Rileva se un host è un'EC2istanza
Potrebbe essere necessario sapere se l'applicazione o il sito Web è in esecuzione su un'EC2istanza, soprattutto se si dispone di un ambiente di elaborazione misto. È possibile utilizzare una delle seguenti opzioni per determinare se l'host dell'applicazione o del sito Web è un'EC2istanza.
Ispezionare l'Documenti di identità dell'istanza
Ogni istanza ha un documento di identità dell'istanza firmato che puoi verificare crittograficamente. Puoi trovare questi documenti utilizzando Instance Metadata Service (IMDS).
Per ulteriori informazioni, consulta Documenti di identità dell'istanza.
Ispeziona il sistema UUID
Potete scaricare il sistema UUID e cercare nell'ottetto iniziale della forma EC2
(in Linux, potrebbe essere in minuscolo). UUID ec2
Questo metodo è rapido, ma potenzialmente impreciso perché c'è una piccola possibilità che un sistema che non è un'EC2istanza possa avere una UUID che inizia con questi caratteri. Inoltre, alcune versioni SMBIOS utilizzano il formato little-endian, che non include EC2
all'inizio di. UUID Questo potrebbe essere il caso EC2 delle istanze che utilizzano SMBIOS 2.4 per Windows o delle distribuzioni Linux diverse da Amazon Linux che dispongono di una propria implementazione di. SMBIOS
Esempio Linux: Get the UUID from DMI (only) HVM AMIs
Usa il seguente comando per UUID utilizzare la Desktop Management Interface (DMI):
[ec2-user ~]$
sudo dmidecode --string system-uuid
Nel seguente output di esempio, UUID inizia con "EC2«, il che indica che il sistema è probabilmente un'EC2istanza.
EC2E1916-9099-7CAF-FD21-012345ABCDEF
Nell'output di esempio seguente, UUID è rappresentato in formato little-endian.
45E12AEC-DCD1-B213-94ED-012345ABCDEF
In alternativa, per le istanze create sul sistema Nitro, è possibile utilizzare il seguente comando:
[ec2-user ~]$
cat /sys/devices/virtual/dmi/id/board_asset_tag
Se l'output è un ID di istanza, come indicato nell'esempio seguente, il sistema è un'istanza: EC2
i-0af01c0123456789a
Esempio Linux: scarica il file UUID dall'hypervisor (solo AMIs PV)
Usa il seguente comando per ottenere il UUID dall'hypervisor:
[ec2-user ~]$
cat /sys/hypervisor/uuid
Nel seguente output di esempio, UUID inizia con «ec2", che indica che il sistema è probabilmente un'istanza. EC2
ec2e1916-9099-7caf-fd21-012345abcdef
Esempio di Windows: ottieni l'UUIDutilizzo WMI di Windows PowerShell
Utilizzate la riga di comando di Windows Management Instrumentation (WMIC) come segue:
wmic path win32_computersystemproduct get uuid
In alternativa, se si utilizza Windows PowerShell, utilizzare il Get-WmiObject cmdlet come segue:
PS C:\>
Get-WmiObject -query "select uuid from Win32_ComputerSystemProduct" | Select UUID
Nell'output di esempio seguente, UUID inizia con "EC2«, il che indica che il sistema è probabilmente un'EC2istanza.
EC2AE145-D1DC-13B2-94ED-012345ABCDEF
Per le istanze che utilizzano SMBIOS 2.4, UUID potrebbe essere rappresentato in formato little-endian; ad esempio:
45E12AEC-DCD1-B213-94ED-012345ABCDEF
Ispezione dell'identificatore di generazione della macchina virtuale del sistema
Un identificatore di generazione della macchina virtuale è costituito da un buffer univoco di 128 bit interpretato come identificatore intero casuale crittografico. È possibile recuperare l'identificatore di generazione della macchina virtuale per identificare l'istanza di Amazon Elastic Compute Cloud. L'identificatore di generazione è esposto all'interno del sistema operativo guest dell'istanza tramite una voce di tabella. ACPI Il valore cambierà se la macchina viene clonata, copiata o importata in AWS, come con VM Import/Export.
Esempio: Recupera l'identificatore di generazione della macchina virtuale da Linux
Puoi utilizzare i seguenti comandi per recuperare l'identificatore di generazione della macchina virtuale dalle istanze che eseguono Linux.
- Amazon Linux 2
-
-
Aggiorna i pacchetti software esistenti, se necessario, utilizzando il seguente comando:
sudo yum update
-
Se necessario, utilizza il pacchetto busybox utilizzando il seguente comando:
sudo curl https://www.rpmfind.net/linux/epel/next/8/Everything/x86_64/Packages/b/busybox-1.35.0-2.el8.next.x86_64.rpm --output busybox.rpm
-
Se necessario, installa i pacchetti prerequisiti utilizzando il seguente comando:
sudo yum install busybox.rpm iasl -y
-
Eseguite il iasl
comando seguente per produrre l'output dalla ACPI tabella:
sudo iasl -p ./SSDT2 -d /sys/firmware/acpi/tables/SSDT2
-
Esegui il comando seguente per esaminare l'output del comando iasl
:
cat SSDT2.dsl
L'output deve restituire lo spazio degli indirizzi necessario per recuperare l'identificatore di generazione della macchina virtuale:
Intel ACPI Component Architecture
ASL+ Optimizing Compiler/Disassembler version 20190509
Copyright (c) 2000 - 2019 Intel Corporation
File appears to be binary: found 32 non-ASCII characters, disassembling
Binary file appears to be a valid ACPI table, disassembling
Input file /sys/firmware/acpi/tables/SSDT2, Length 0x7B (123) bytes
ACPI: SSDT 0x0000000000000000 00007B (v01 AMAZON AMZNSSDT 00000001 AMZN 00000001)
Pass 1 parse of [SSDT]
Pass 2 parse of [SSDT]
Parsing Deferred Opcodes (Methods/Buffers/Packages/Regions)
Parsing completed
Disassembly completed
ASL Output: ./SSDT2.dsl - 1065 bytes
$
/*
* Intel ACPI Component Architecture
* AML/ASL+ Disassembler version 20190509 (64-bit version)
* Copyright (c) 2000 - 2019 Intel Corporation
*
* Disassembling to symbolic ASL+ operators
*
* Disassembly of /sys/firmware/acpi/tables/SSDT2, Tue Mar 29 16:15:14 2022
*
* Original Table Header:
* Signature "SSDT"
* Length 0x0000007B (123)
* Revision 0x01
* Checksum 0xB8
* OEM ID "AMAZON"
* OEM Table ID "AMZNSSDT"
* OEM Revision 0x00000001 (1)
* Compiler ID "AMZN"
* Compiler Version 0x00000001 (1)
*/
DefinitionBlock ("", "SSDT", 1, "AMAZON", "AMZNSSDT", 0x00000001)
{
Scope (\_SB)
{
Device (VMGN)
{
Name (_CID, "VM_Gen_Counter") // _CID: Compatible ID
Name (_DDN, "VM_Gen_Counter") // _DDN: DOS Device Name
Name (_HID, "AMZN0000") // _HID: Hardware ID
Name (ADDR, Package (0x02)
{
0xFED01000
,
Zero
})
}
}
}
-
(Opzionale) Aumenta le autorizzazioni del terminale per i passaggi rimanenti con il seguente comando:
sudo -s
-
Utilizza il comando seguente per archiviare lo spazio degli indirizzi precedentemente raccolto:
VMGN_ADDR=0xFED01000
-
Utilizza il comando seguente per scorrere lo spazio degli indirizzi e creare l'identificatore di generazione della macchina virtuale:
for offset in 0x0 0x4 0x8 0xc; do busybox devmem $(($VMGN_ADDR + $offset)) | sed 's/0x//' | sed -z '$ s/\n$//' >> vmgenid; done
-
Recupera l'identificatore di generazione della macchina virtuale dal file di output con il seguente comando:
cat vmgenid ; echo
L'output visualizzato dovrebbe essere simile al seguente:
EC2F335D979132C4165896753E72BD1C
- Ubuntu
-
-
Aggiorna i pacchetti software esistenti, se necessario, utilizzando il seguente comando:
sudo apt update
-
Se necessario, installa i pacchetti prerequisiti utilizzando il seguente comando:
sudo apt install busybox iasl -y
-
Eseguite il iasl
comando seguente per produrre l'output dalla ACPI tabella:
sudo iasl -p ./SSDT2 -d /sys/firmware/acpi/tables/SSDT2
-
Esegui il comando seguente per esaminare l'output del comando iasl
:
cat SSDT2.dsl
L'output deve restituire lo spazio degli indirizzi necessario per recuperare l'identificatore di generazione della macchina virtuale:
Intel ACPI Component Architecture
ASL+ Optimizing Compiler/Disassembler version 20190509
Copyright (c) 2000 - 2019 Intel Corporation
File appears to be binary: found 32 non-ASCII characters, disassembling
Binary file appears to be a valid ACPI table, disassembling
Input file /sys/firmware/acpi/tables/SSDT2, Length 0x7B (123) bytes
ACPI: SSDT 0x0000000000000000 00007B (v01 AMAZON AMZNSSDT 00000001 AMZN 00000001)
Pass 1 parse of [SSDT]
Pass 2 parse of [SSDT]
Parsing Deferred Opcodes (Methods/Buffers/Packages/Regions)
Parsing completed
Disassembly completed
ASL Output: ./SSDT2.dsl - 1065 bytes
$
/*
* Intel ACPI Component Architecture
* AML/ASL+ Disassembler version 20190509 (64-bit version)
* Copyright (c) 2000 - 2019 Intel Corporation
*
* Disassembling to symbolic ASL+ operators
*
* Disassembly of /sys/firmware/acpi/tables/SSDT2, Tue Mar 29 16:15:14 2022
*
* Original Table Header:
* Signature "SSDT"
* Length 0x0000007B (123)
* Revision 0x01
* Checksum 0xB8
* OEM ID "AMAZON"
* OEM Table ID "AMZNSSDT"
* OEM Revision 0x00000001 (1)
* Compiler ID "AMZN"
* Compiler Version 0x00000001 (1)
*/
DefinitionBlock ("", "SSDT", 1, "AMAZON", "AMZNSSDT", 0x00000001)
{
Scope (\_SB)
{
Device (VMGN)
{
Name (_CID, "VM_Gen_Counter") // _CID: Compatible ID
Name (_DDN, "VM_Gen_Counter") // _DDN: DOS Device Name
Name (_HID, "AMZN0000") // _HID: Hardware ID
Name (ADDR, Package (0x02)
{
0xFED01000
,
Zero
})
}
}
}
-
(Opzionale) Aumenta le autorizzazioni del terminale per i passaggi rimanenti con il seguente comando:
sudo -s
-
Utilizza i comandi seguenti per archiviare lo spazio degli indirizzi precedentemente raccolto:
VMGN_ADDR=0xFED01000
-
Utilizza il comando seguente per scorrere lo spazio degli indirizzi e creare l'identificatore di generazione della macchina virtuale:
for offset in 0x0 0x4 0x8 0xc; do busybox devmem $(($VMGN_ADDR + $offset)) | sed 's/0x//' | sed -z '$ s/\n$//' >> vmgenid; done
-
Recupera l'identificatore di generazione della macchina virtuale dal file di output con il seguente comando:
cat vmgenid ; echo
L'output visualizzato dovrebbe essere simile al seguente:
EC2F335D979132C4165896753E72BD1C
Esempio: recupera l'identificatore di generazione della macchina virtuale da Windows
È possibile creare un'applicazione di esempio per recuperare l'identificatore di generazione della macchina virtuale dalle istanze che eseguono Windows. Per ulteriori informazioni, consulta Obtaining the virtual machine generation identifier (Ottenimento dell'identificatore di generazione della macchina virtuale) nella documentazione Microsoft.