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à.
Modifiche nell'utilità EC2 dei metadati dalla versione 1 alla versione 2
Questo argomento descrive in dettaglio le modifiche all'utilità di metadati SDK per Java Amazon Elastic Compute Cloud (EC2) dalla versione 1 (v1) alla versione 2 (v2).
Modifiche di alto livello
Modifica | v1 | v2 |
---|---|---|
Dipendenze da Maven |
|
|
Nome pacchetto |
com.amazonaws.util |
software.amazon.awssdk.imds |
Approccio all'istanziazione |
Utilizza metodi di utilità statici; nessuna istanziazione:
|
Usa un metodo di fabbrica statico:
Oppure usa un approccio da costruttore:
|
Tipi di clienti | Metodi di utilità solo sincroni: EC2MetadataUtils |
Sincrono: Asincrono: |
1 Ultima versione.
3 Notate la dichiarazione del apache-client
modulo per la v2. La versione 2 dell'utilità per i EC2 metadati richiede un'implementazione dell'SdkHttpClient
interfaccia per il client di metadati sincrono o dell'SdkAsyncHttpClient
interfaccia per il client di metadati asincrono. La HTTPclienti sezione mostra l'elenco dei client che è possibile utilizzare. HTTP
Richiesta di metadati
Nella v1, si utilizzano metodi statici che non accettano parametri per richiedere i metadati per una risorsa. EC2 Al contrario, è necessario specificare il percorso della EC2 risorsa come parametro nella v2. La tabella seguente mostra i diversi approcci.
v1 | v2 |
---|---|
|
|
Fate riferimento alle categorie di metadati delle istanze per trovare il percorso da fornire per richiedere una parte di metadati.
Nota
Quando utilizzi un client di metadati di istanza nella v2, dovresti mirare a utilizzare lo stesso client per tutte le richieste di recupero dei metadati.
Modifiche al comportamento
JSONdati
AttivoEC2, Instance Metadata Service (IMDS) in esecuzione localmente restituisce alcuni metadati come stringhe JSON formattate. Uno di questi esempi sono i metadati dinamici di un documento di identità di istanza.
La v1 API contiene metodi separati per ogni parte dei metadati di identità dell'istanza, mentre la v2 restituisce API direttamente la stringa. JSON Per lavorare con la JSON stringa, puoi usare il Document API
La tabella seguente confronta il modo in cui si recuperano i metadati di un documento di identità di istanza in v1 e v2.
Caso d'uso | v1 | v2 |
---|---|---|
Recupera la regione |
|
|
Recupera l'id dell'istanza |
|
|
Recupera il tipo di istanza |
|
|
Differenze di risoluzione degli endpoint
La tabella seguente mostra le posizioni in cui vengono SDK effettuati i controlli per risolvere l'endpoint. IMDS Le posizioni sono elencate con priorità decrescente.
v1 | v2 |
---|---|
Proprietà del sistema: com.amazonaws.sdk.ec2MetadataServiceEndpointOverride |
Metodo di configurazione di Client Builder: endpoint(...) |
Variabile d'ambiente: AWS_EC2_METADATA_SERVICE_ENDPOINT |
Proprietà del sistema: aws.ec2MetadataServiceEndpoint |
Valore predefinito: http://169.254.169.254 |
File di configurazione: ~.aws/config con l'impostazione ec2_metadata_service_endpoint |
Valore associato a risolto endpoint-mode |
|
Valore predefinito: http://169.254.169.254 |
Risoluzione dell'endpoint in v2
Quando imposti esplicitamente un endpoint utilizzando il builder, quel valore dell'endpoint ha la priorità su tutte le altre impostazioni. Quando viene eseguito il codice seguente, la proprietà di aws.ec2MetadataServiceEndpoint
sistema e l'ec2_metadata_service_endpoint
impostazione del file di configurazione vengono ignorate, se esistono.
Ec2MetadataClient client = Ec2MetadataClient
.builder()
.endpoint(URI.create("endpoint.to.use
"))
.build();
modalità Endpoint
Con la v2, puoi specificare una modalità endpoint per configurare il client di metadati in modo che utilizzi i valori di endpoint predefiniti per o. IPv4 IPv6 La modalità endpoint non è disponibile per la versione 1. Il valore predefinito utilizzato per è e forIPv4. http://169.254.169.254
http://[fd00:ec2::254]
IPv6
La tabella seguente mostra i diversi modi in cui è possibile impostare la modalità endpoint in ordine di priorità decrescente.
Valori possibili | ||
---|---|---|
Metodo di configurazione di Client Builder: endpointMode(...) |
|
EndpointMode.IPV4 ,
EndpointMode.IPV6 |
Proprietà del sistema | aws.ec2MetadataServiceEndpointMode |
IPv4 , IPv6 (il caso non ha importanza) |
File di configurazione: ~.aws/config |
ec2_metadata_service_endpoint Impostazione |
IPv4 , IPv6 (il caso non ha importanza) |
Non specificato nei modi precedenti | IPv4è usato |
Come si SDK risolve endpoint
o endpoint-mode
nella v2
-
SDKUtilizza il valore impostato nel codice sul client builder e ignora qualsiasi impostazione esterna. Poiché SDK genera un'eccezione se entrambi
endpoint
endpointMode
vengono chiamati sul client builder, SDK utilizza il valore dell'endpoint indipendentemente dal metodo utilizzato. -
Se non imposti un valore nel codice, SDK cerca la configurazione esterna, prima per le proprietà del sistema e poi per un'impostazione nel file di configurazione.
-
Il SDK primo verifica il valore di un endpoint. Se viene trovato un valore, viene utilizzato.
-
Se non ha SDK ancora trovato un valore, SDK cerca le impostazioni della modalità endpoint.
-
-
Infine, se non SDK trova alcuna impostazione esterna e non è stato configurato il client di metadati nel codice, SDK utilizza il IPv4 valore di.
http://169.254.169.254
IMDSv2
Amazon EC2 definisce due approcci per accedere ai metadati delle istanze:
-
Instance Metadata Service versione 1 (IMDSv1): approccio di richiesta/risposta
-
Instance Metadata Service Version 2 ()IMDSv2: approccio orientato alla sessione
La tabella seguente confronta il funzionamento di Java con. SDKs IMDS
v1 | v2 |
---|---|
IMDSv2viene utilizzato per impostazione predefinita | Usa sempre IMDSv2 |
Tenta di recuperare un token di sessione per ogni richiesta e torna indietro IMDSv1 se non riesce a recuperare un token di sessione | Mantiene un token di sessione in una cache interna che viene riutilizzata per più richieste |
Il SDK for Java 2.x supporta solo IMDSv2 e non ricorre a. IMDSv1
Differenze di configurazione
La tabella seguente elenca le diverse opzioni di configurazione.
Configurazione | v1 | v2 |
---|---|---|
Tentativi | Configurazione non disponibile | Configurabile tramite il metodo builder retryPolicy(...) |
HTTP | Timeout di connessione configurabile tramite la variabile di ambiente. AWS_METADATA_SERVICE_TIMEOUT L'impostazione predefinita è 1 secondo. |
Configurazione disponibile passando un HTTP client al metodo httpClient(...) builder. Il timeout di connessione predefinito per HTTP i client è di 2 secondi. |
Esempio di configurazione v2 HTTP
L'esempio seguente mostra come configurare il client di metadati. Questo esempio configura il timeout della connessione e utilizza il client Apache. HTTP
SdkHttpClient httpClient = ApacheHttpClient.builder() .connectionTimeout(Duration.ofSeconds(1)) .build(); Ec2MetadataClient imdsClient = Ec2MetadataClient.builder() .httpClient(httpClient) .build();