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 for 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 Client HTTP sezione mostra l'elenco dei client HTTP che è possibile utilizzare.
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
Dati JSON
Attivo EC2, l'Instance Metadata Service (IMDS) in esecuzione locale restituisce alcuni metadati come stringhe in formato JSON. Uno di questi esempi sono i metadati dinamici di un documento di identità di istanza.
L'API v1 contiene metodi separati per ogni parte dei metadati di identità dell'istanza, mentre l'API v2 restituisce direttamente la stringa JSON. Per lavorare con la stringa JSON, puoi utilizzare l'API Document
La tabella seguente confronta il modo in cui recuperi 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 controllate dall'SDK per risolvere l'endpoint in 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 for IPv4 . 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 risolve endpoint
l'SDK o nella v2 endpoint-mode
-
L'SDK utilizza il valore impostato nel codice nel client builder e ignora qualsiasi impostazione esterna. Poiché l'SDK genera un'eccezione se entrambi
endpoint
endpointMode
vengono chiamati sul client builder, l'SDK utilizza il valore dell'endpoint indipendentemente dal metodo utilizzato. -
Se non imposti un valore nel codice, l'SDK esamina la configurazione esterna, prima per le proprietà del sistema e poi per un'impostazione nel file di configurazione.
-
L'SDK verifica innanzitutto la presenza di un valore dell'endpoint. Se viene trovato un valore, viene utilizzato.
-
Se l'SDK non ha ancora trovato un valore, l'SDK cerca le impostazioni della modalità endpoint.
-
-
Infine, se l'SDK non trova impostazioni esterne e non hai configurato il client di metadati nel codice, l'SDK utilizza il valore di. IPv4
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 modo in cui Java SDKs funziona con IMDS.
v1 | v2 |
---|---|
IMDSv2 viene 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 |
L'SDK for Java 2.x supporta IMDSv2 solo 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 client HTTP al metodo httpClient(...) builder. Il timeout di connessione predefinito per i client HTTP è di 2 secondi. |
Esempio di configurazione HTTP v2
L'esempio seguente mostra come configurare il client di metadati. Questo esempio configura il timeout della connessione e utilizza il client HTTP Apache.
SdkHttpClient httpClient = ApacheHttpClient.builder() .connectionTimeout(Duration.ofSeconds(1)) .build(); Ec2MetadataClient imdsClient = Ec2MetadataClient.builder() .httpClient(httpClient) .build();