Questa pagina descrive il funzionamento delle intestazioni personalizzate nelle mappe degli URL utilizzate dai bilanciatori del carico delle applicazioni interni regionali e dai bilanciatori del carico delle applicazioni interni tra regioni.
Le intestazioni delle richieste e delle risposte personalizzate ti consentono di specificare intestazioni aggiuntive che il bilanciatore del carico può aggiungere alle richieste e alle risposte HTTP(S). A seconda delle informazioni rilevate dal bilanciamento del carico, queste intestazioni possono includere le seguenti informazioni:
- Latenza verso il client
Parametri della connessione TLS
Prima di iniziare
Se necessario, esegui l'aggiornamento all'ultima versione di Google Cloud CLI:
gcloud components update
Come funzionano le intestazioni personalizzate
Le intestazioni personalizzate funzionano nel seguente modo:
Quando il bilanciatore del carico effettua una richiesta al backend, aggiunge le intestazioni della richiesta.
Il bilanciatore del carico aggiunge intestazioni delle richieste personalizzate solo alle richieste client, non ai probe del controllo di integrità. Se il backend richiede un'intestazione specifica per l'autorizzazione che non è presente nel pacchetto del controllo di integrità, il controllo di integrità potrebbe non riuscire.
Il bilanciatore del carico imposta le intestazioni di risposta prima di restituire una risposta al client.
Per attivare le intestazioni personalizzate per i bilanciatori del carico delle applicazioni interni a livello di regione e tra regioni, devi specificare un elenco di nomi e valori di intestazione nel file di configurazione della mappa URL.
I nomi delle intestazioni devono avere le seguenti proprietà:
- Il nome dell'intestazione deve essere una definizione valida del nome del campo di intestazione HTTP secondo il documento RFC 7230.
- Il nome dell'intestazione non deve essere
X-User-IP
. - Il nome dell'intestazione non deve iniziare con
X-Google
,X-Goog-
,X-GFE
oX-Amz-
. - Non devono essere utilizzati i seguenti header hop-by-hop:
Keep-Alive
,Transfer-Encoding
,TE
,Connection
,Trailer
eUpgrade
. In conformità con RFC 2616, queste intestazioni non vengono memorizzate dalle cache o propagate dai proxy di destinazione. - Il nome dell'intestazione non deve essere
Host
oauthority
.Host
eauthority
sono parole chiave speciali riservate da Google Cloud. Non puoi modificare queste intestazioni per i bilanciatori del carico basati su Envoy. Ti consigliamo invece di creare altre intestazioni personalizzate (ad esempio,MyHost
) per non interferire con i nomi delle intestazioni riservate. - Il nome di un'intestazione non deve comparire più di una volta nell'elenco delle intestazioni.
I nomi delle intestazioni non fanno distinzione tra maiuscole e minuscole. Quando i nomi delle intestazioni vengono passati a un backend HTTP/2, il protocollo HTTP/2 codifica i nomi delle intestazioni in lettere minuscole.
I valori di intestazione devono avere le seguenti proprietà:
- Il valore dell'intestazione deve essere una definizione valida del campo di intestazione HTTP secondo il documento RFC 7230, con i moduli obsoleti non consentiti.
- Il valore dell'intestazione non può essere vuoto. Le intestazioni vuote vengono rifiutate.
- Il valore dell'intestazione può includere una o più variabili, racchiuse tra parentesi graffe, che si espandono ai valori forniti dal bilanciatore del carico. Per un elenco completo delle variabili consentite nel valore dell'intestazione, consulta Variabili che possono essere visualizzate nel valore dell'intestazione.
Nei valori di intestazione, gli spazi vuoti iniziali e finali non sono significativi
e non vengono passati al backend. Per consentire le parentesi graffe nei valori di intestazione,
il bilanciatore del carico interpreta due parentesi graffe aperte ({{
) come
una singola parentesi graffa aperta ({
) e due parentesi graffe chiuse (}}
) come una singola
parentesi graffa chiusa (}
).
Aggiungere intestazioni di richiesta o risposta
Per aggiungere intestazioni di richiesta o risposta, utilizza gcloud CLI per modificare la mappa URL nel seguente modo:
Regionale
gcloud compute url-maps edit URL_MAP_NAME \ --region=REGION
Di seguito è riportato un file YAML di esempio che mostra come utilizzare le variabili nelle intestazioni personalizzate:
defaultService: regions/REGION/backendServices/BACKEND_SERVICE_1 name: regional-lb-map region: region/REGION hostRules: - hosts: - '*' pathMatcher: matcher1 pathMatchers: - defaultService: regions/REGION/backendServices/BACKEND_SERVICE_1 name: matcher1 routeRules: - matchRules: - prefixMatch: /PREFIX priority: PRIORITY # 0 is highest routeAction: weightedBackendServices: - backendService: regions/REGION/backendServices/BACKEND_SERVICE_1 weight: 100 headerAction: requestHeadersToAdd: - headerName: X-header-1-client-region headerValue: "{client_region}" - headerName: X-header-2-client-ip-port headerValue: "{client_ip_address}, {client_port}" replace: True requestHeadersToRemove: - header-3-name responseHeadersToAdd: - headerName: X-header-4-server-ip-port headerValue: "{server_ip_address}, {server_port}" replace: True responseHeadersToRemove: - header-5-name - header-6-name
Tra regioni
gcloud compute url-maps edit URL_MAP_NAME \ --global
Di seguito è riportato un file YAML di esempio che mostra come utilizzare le variabili nelle intestazioni personalizzate:
defaultService: global/backendServices/BACKEND_SERVICE_1 name: global-lb-map hostRules: - hosts: - '*' pathMatcher: matcher1 pathMatchers: - defaultService: global/backendServices/BACKEND_SERVICE_1 name: matcher1 routeRules: - matchRules: - prefixMatch: /PREFIX priority: PRIORITY # 0 is highest routeAction: weightedBackendServices: - backendService: global/backendServices/BACKEND_SERVICE_1 weight: 100 headerAction: requestHeadersToAdd: - headerName: X-header-1-client-region headerValue: "{client_region}" - headerName: X-header-2-client-ip-port headerValue: "{client_ip_address}, {client_port}" replace: True requesteHeadersToRemove: - header-3-name responseHeadersToAdd: - headerName: X-header-4-server-ip-port headerValue: "{server_ip_address}, {server_port}" replace: True responseHeadersToRemove: - header-5-name - header-6-name
Tieni presente i seguenti comportamenti:
- Se un'intestazione della risposta con variabili personalizzate viene risolta in una stringa vuota, viene rimossa.
- Se un'intestazione della richiesta con variabili personalizzate viene risolta in una stringa vuota, viene conservata con un segnaposto di stringa vuota.
- Se un'intestazione della richiesta personalizzata include una variabile personalizzata e una richiesta client in entrata include anche la stessa intestazione, il valore dell'intestazione della richiesta client verrà sostituito con il nuovo valore fornito dall'intestazione personalizzata del bilanciamento del carico.
Variabili che possono essere visualizzate nel valore dell'intestazione
Nei valori delle intestazioni personalizzate possono essere visualizzate le seguenti variabili.
Variabile | Descrizione |
---|---|
client_rtt_msec |
Tempo di trasmissione di round trip stimato tra il bilanciatore del carico e il client HTTP(S), in millisecondi. Questo è il parametro tempo di round trip (SRTT) uniforme misurato dallo stack TCP del bilanciatore del carico, in base a RFC 2988. L'RTT uniforme è un algoritmo che gestisce le variazioni e le anomalie che possono verificarsi nelle misurazioni dell'RTT. |
client_ip_address |
L'indirizzo IP del client. Di solito corrisponde all'indirizzo IP client
che è il penultimo indirizzo nell'intestazione
X-Forwarded-For , a meno che il client non utilizzi un proxy o l'intestazione
X-Forwarded-For non sia stata manomessa. |
client_port |
La porta di origine del client. |
client_encrypted |
true se la connessione tra il client e il
bilanciatore del carico è criptata (utilizzando HTTPS, HTTP/2 o HTTP/3); altrimenti,
false .
|
client_protocol |
Il protocollo HTTP utilizzato per la comunicazione tra il client e il
bilanciatore del carico. Uno dei valori HTTP/1.0 , HTTP/1.1 ,
HTTP/2 o HTTP/3 .
|
origin_request_header |
Riflette il valore dell'intestazione Origin nella richiesta
per i casi d'uso della condivisione delle risorse tra origini (CORS).
|
server_ip_address |
L'indirizzo IP del bilanciatore del carico a cui si connette il client. Questo
può essere utile quando più bilanciatori del carico condividono backend comuni. Questo
è uguale all'ultimo indirizzo IP nell'intestazione
X-Forwarded-For .
|
server_port |
Il numero di porta di destinazione a cui si connette il client. |
tls_sni_hostname |
Indicazione del nome del server (come definito nella RFC 6066), se fornita dal client durante l'handshake TLS o QUIC. Il nome host viene convertito in minuscolo e viene rimosso qualsiasi punto finale. |
tls_version |
Versione TLS negoziata tra il client e il bilanciatore del carico durante l'handshake SSL. I valori possibili includono: TLSv1 ,
TLSv1.1 , TLSv1.2 e TLSv1.3 . Se
il client si connette utilizzando QUIC anziché TLS, il valore è
QUIC .
|
tls_cipher_suite |
Suite di crittografia negoziata durante il TLS handshake. Il valore è costituito da quattro
cifre esadecimali definite dal
registro delle suite di crittografia
TLS dell'IANA, ad esempio 009C per TLS_RSA_WITH_AES_128_GCM_SHA256. Questo
valore è vuoto per QUIC e per le connessioni client non criptate.
|
tls_ja3_fingerprint |
JA3 Impronta TLS/SSL se il client si connette utilizzando HTTPS, HTTP/2 o HTTP/3. |
Il bilanciatore del carico espande le variabili a stringhe vuote quando non riesce a determinarne i valori. Ad esempio:
- Parametri TLS quando TLS non è in uso
{origin_request_header}
quando la richiesta non include un'intestazioneOrigin
I valori geografici sono stime basate sull'indirizzo IP del client. Di tanto in tanto, Google aggiorna i dati che forniscono questi valori per migliorare l'accuratezza e riflettere i cambiamenti geografici e politici. Anche se l'intestazione
X-Forwarded-For
originale contiene informazioni sulla posizione valide, Google stima
le posizioni dei client utilizzando le informazioni sull'indirizzo IP di origine contenute nei pacchetti
ricevuti dal bilanciatore del carico.
Intestazioni personalizzate TLS reciproca
Le seguenti variabili di intestazione aggiuntive sono disponibili se TLS reciproco (mTLS) è configurato in TargetHttpsProxy del bilanciatore del carico.
Variabile | Descrizione |
---|---|
client_cert_present |
true se il
client ha fornito un certificato durante l'handshake TLS; altrimenti, false .
|
client_cert_chain_verified |
true se la
catena di certificati client viene verificata in base a un TrustStore configurato; altrimenti, false .
|
client_cert_error |
Stringhe predefinite che rappresentano le condizioni di errore. Per ulteriori informazioni sulle stringhe di errore, vedi Modalità di convalida client mTLS. |
client_cert_sha256_fingerprint |
Impronta SHA-256 con codifica Base64 del certificato client. |
client_cert_serial_number |
Il numero di serie del certificato client.
Se il numero di serie è più lungo di 50 byte, la stringa
client_cert_serial_number_exceeded_size_limit viene aggiunta a
client_cert_error e il
numero di serie viene impostato su una stringa vuota. |
client_cert_spiffe_id |
L'ID SPIFFE dal campo Nome alternativo del soggetto (SAN). Se il valore non è valido o supera i 2048 byte, l'ID SPIFFE viene impostato su una stringa vuota. Se l'ID SPIFFE è più lungo di 2048 byte, la stringa
|
client_cert_uri_sans |
Elenco separato da virgole e codificato in base64 delle estensioni SAN di tipo URI.
Le estensioni SAN vengono estratte dal certificato client.
L'ID SPIFFE non è
incluso nel campo Se |
client_cert_dnsname_sans |
Elenco codificato in Base64 e separato da virgole delle estensioni SAN di tipo DNSName. Le estensioni SAN vengono estratte dal certificato client. Se |
client_cert_valid_not_before |
Timestamp (nel formato di stringa per la data RFC 3339) prima del quale il certificato client non è valido.
Ad esempio, 2022-07-01T18:05:09+00:00 .
|
client_cert_valid_not_after |
Timestamp (nel formato di stringa per la data RFC 3339) dopo il quale il certificato client non è valido.
Ad esempio, 2022-07-01T18:05:09+00:00 .
|
client_cert_issuer_dn |
Campo Emittente completo con codifica Base64 del certificato. Se |
client_cert_subject_dn |
Campo Oggetto completo con codifica Base64 del certificato. Se |
client_cert_leaf |
Il certificato foglia client per una connessione mTLS stabilita in cui il certificato ha superato la convalida. La codifica del certificato è conforme alla RFC 9440: il certificato DER binario è codificato utilizzando Base64 (senza interruzioni di riga, spazi o altri caratteri al di fuori dell'alfabeto Base64) e delimitato da due punti su entrambi i lati. Se |
client_cert_chain |
L'elenco separato da virgole dei certificati, nell'ordine TLS standard, della catena di certificati client per una connessione mTLS stabilita in cui il certificato client ha superato la convalida, escluso il certificato foglia. La codifica del certificato è conforme a RFC 9440. Se la dimensione combinata di |
Limitazioni
Si applicano le seguenti limitazioni:
- Non puoi configurare intestazioni personalizzate sui servizi di backend utilizzati dai bilanciatori del carico delle applicazioni interni regionali e dai bilanciatori del carico delle applicazioni interni tra regioni.