Questa pagina ti guida alla creazione di una subnet globale in Google Distributed Cloud (GDC) air-gapped e all'utilizzo di questa subnet per un bilanciatore del carico interno (ILB).
Le subnet globali consentono di configurare le operazioni di bilanciamento del carico interno in più zone della tua organizzazione GDC. Il bilanciamento del carico offre i vantaggi di prestazioni, affidabilità e disponibilità migliorate di applicazioni e servizi distribuendo il traffico di rete su più server. Per saperne di più sulle subnet globali per il bilanciamento del carico, consulta Informazioni sulle subnet per il bilanciamento del carico.
Questa pagina è rivolta agli sviluppatori del gruppo di operatori di applicazioni che vogliono gestire il bilanciamento del carico per la propria organizzazione. Per ulteriori informazioni, consulta la documentazione sulle audience per GDC air-gapped.
Prima di iniziare
Per creare una subnet globale e configurarla per i bilanciatori del carico interni, devi disporre di quanto segue:
- Essere proprietario del progetto per cui stai configurando il bilanciatore del carico. Per saperne di più, consulta Creare un progetto.
I ruoli di identità e accesso necessari:
- Chiedi all'amministratore IAM dell'organizzazione di concederti il ruolo Amministratore bilanciatore del carico
(
load-balancer-admin
). - Chiedi all'amministratore IAM dell'organizzazione di concederti il ruolo Amministratore del bilanciamento del carico globale (
global-load-balancer-admin
). - Chiedi all'amministratore IAM dell'organizzazione di concederti il ruolo Amministratore organizzazione subnet (
subnet-org-admin
). - Chiedi all'amministratore IAM dell'organizzazione di concederti il ruolo Amministratore progetto subnet (
subnet-project-admin
).
Per ulteriori informazioni, consulta Descrizioni dei ruoli predefiniti.
- Chiedi all'amministratore IAM dell'organizzazione di concederti il ruolo Amministratore bilanciatore del carico
(
Crea una subnet globale principale
La subnet globale principale che crei in questa sezione funge da pool di indirizzi IP
da cui provengono gli indirizzi IP del bilanciatore del carico interno. Specifica i genitori
delle subnet utilizzando il campo spec.parentReference.name
.
Hai due opzioni per configurare il CIDR per questa subnet principale:
- Crea una subnet utilizzando una configurazione CIDR statica
- Crea una subnet utilizzando una configurazione CIDR dinamica
Per ulteriori informazioni sulla differenza tra le configurazioni CIDR statiche e dinamiche, consulta Configurazione CIDR statica e dinamica.
Crea una subnet utilizzando una configurazione CIDR statica
Utilizza una configurazione CIDR statica quando hai bisogno di un controllo preciso dello spazio degli indirizzi IP.
Questa subnet ha un tipo Branch
. Per saperne di più sui tipi di subnet radice, ramo e foglia, consulta Gerarchia delle subnet.
Per creare una subnet principale globale con una configurazione CIDR statica, aggiungi il blocco CIDR
che hai scelto al campo spec.ipv4Request.cidr
:
kubectl --kubeconfig GLOBAL_API_SERVER apply -f - <<EOF
apiVersion: ipam.global.gdc.goog/v1
kind: Subnet
metadata:
labels:
ipam.gdc.goog/vpc: default-vpc
name: ILB_PARENT_SUBNET_NAME
namespace: platform
spec:
ipv4Request:
cidr: STATIC_CIDR
parentReference:
name: PARENT_NAME
namespace: platform
propagationStrategy: None
type: Branch
EOF
Sostituisci quanto segue:
GLOBAL_API_SERVER
: il percorso kubeconfig del server API di gestione globale. Per saperne di più, vedi Server API globali e a livello di zona. Se non hai ancora generato un file kubeconfig per il server API, consulta Accedi per i dettagli.ILB_PARENT_SUBNET_NAME
: il nome scelto per la subnet padre globale per il bilanciatore del carico interno.STATIC_CIDR
: il blocco CIDR specifico che vuoi allocare per questa subnet principale, ad esempio10.0.10.0/27
.PARENT_NAME
: il nome della subnet principale esistente da cui viene creata questa nuova subnet.
Per configurare questa subnet in modo che funzioni con i bilanciatori del carico interni, devi creare una subnet foglia per il bilanciatore del carico interno.
Crea una subnet utilizzando una configurazione CIDR dinamica
La configurazione CIDR dinamica alloca automaticamente un blocco CIDR disponibile
di una dimensione specificata dalla subnet principale. Ciò semplifica la gestione degli indirizzi IP, soprattutto in ambienti di grandi dimensioni.
Questa subnet ha un tipo Branch
. Per saperne di più sui tipi di subnet radice, ramo e foglia, consulta Gerarchia delle subnet.
Per creare una subnet principale globale con un CIDR dinamico, configura il
campo spec.ipv4Request.prefixLength
con la lunghezza del prefisso scelta:
kubectl --kubeconfig GLOBAL_API_SERVER apply -f - <<EOF
apiVersion: ipam.global.gdc.goog/v1
kind: Subnet
metadata:
labels:
ipam.gdc.goog/vpc: default-vpc
name: ILB_PARENT_SUBNET_NAME
namespace: platform
spec:
ipv4Request:
prefixLength: PREFIX_LENGTH
parentReference:
name: PARENT_NAME
namespace: platform
propagationStrategy: None
type: Branch
EOF
Sostituisci quanto segue:
ILB_PARENT_SUBNET_NAME
: il nome che hai scelto per la subnet padre del bilanciatore del carico interno, ad esempiolb-global-lancer-ilb-subnet
.STATIC_CIDR
: il blocco CIDR specifico che vuoi utilizzare, ad esempio10.0.10.0/27
. Questa variabile è applicabile solo alla configurazione CIDR statica.PARENT_NAME
: il nome della subnet principale esistente da cui viene creata questa nuova subnet, ad esempiodefault-vpc-workload-cidr
.PREFIX_LENGTH
: la lunghezza del prefisso scelta per il CIDR allocato dinamicamente, ad esempio27
. Questa variabile è applicabile solo alla configurazione CIDR dinamica.
Per configurare questa subnet in modo che funzioni con i bilanciatori del carico interni, devi creare una subnet foglia per il bilanciatore del carico interno.
Crea una subnet leaf per il bilanciamento del carico interno
Dopo aver configurato la subnet principale globale, devi creare una subnet foglia per
allocare un singolo indirizzo IP per il servizio di bilanciamento del carico interno globale. Questa subnet foglia deve
avere un valore del campo type
pari a Leaf
e deve risiedere nello stesso spazio dei nomi del progetto
delle risorse del bilanciatore del carico, come ForwardingRule
,
BackendService
e Backend
.
Per creare la subnet foglia e collegarla al bilanciamento del carico interno:
Crea una subnet foglia con un valore
prefixLength
di32
, in quanto è destinata ad allocare un singolo indirizzo IP. Il valoreparentReference
fa riferimento alla subnet globale principale creata in precedenza:kubectl --kubeconfig GLOBAL_API_SERVER apply -f - <<EOF apiVersion: ipam.global.gdc.goog/v1 kind: Subnet metadata: labels: ipam.gdc.goog/allocation-preference: default ipam.gdc.goog/vpc: default-vpc name: ILB_IP_SUBNET_NAME namespace: PROJECT_NAMESPACE spec: ipv4Request: prefixLength: 32 parentReference: name: PARENT_REF namespace: platform type: Leaf EOF
Sostituisci quanto segue:
ILB_IP_SUBNET_NAME
: il nome che hai scelto per la subnet foglia, ad esempiolb-project-ilb-ip
.PROJECT_NAMESPACE
: lo spazio dei nomi Kubernetes corrispondente al tuo progetto in cui si trovano gli oggetti ILB, ad esempiolb-project
.PARENT_REF
: il nome della subnet principale da cui questa subnet foglia ricava il proprio indirizzo IP, ad esempio la subnet globale principale che hai creato in precedenza.
Collega la subnet leaf appena creata, che contiene l'indirizzo IP allocato, alla risorsa
ForwardingRuleInternal
del tuo bilanciamento del carico interno. Nella risorsaForwardingRuleInternal
, aggiorna il campospec.cidrRef.name
in modo che faccia riferimento al nome della subnet foglia che hai creato nel passaggio precedente:kubectl --kubeconfig GLOBAL_API_SERVER apply -f - <<EOF apiVersion: networking.global.gdc.goog/v1 kind: ForwardingRuleInternal metadata: name: FRI_NAME namespace: PROJECT_NAMESPACE spec: ports: - port: PORT protocol: PROTOCOL backendServiceRef: name: BES_NAME cidrRef: name: LEAF_SUBNET_NAME EOF
Sostituisci quanto segue:
FRI_NAME
: il nome che hai scelto per l'oggettoForwardingRuleInternal
, ad esempionginx-ilb-static-fr
.PORT
: il numero di porta su cui il bilanciatore del carico interno è in ascolto del traffico in entrata, ad esempio80
.PROTOCOL
: il protocollo di rete utilizzato dal bilanciamento del carico interno, ad esempioTCP
oUDP
.BES_NAME
: il nome diBackendService
associato a questa risorsaForwardingRuleInternal
, ad esempionginx-bes
.LEAF_SUBNET_NAME
: il nome della subnet foglia che hai creato nel passaggio precedente, ad esempiolb-project-ilb-ip
.