Pubblicare servizi utilizzando Private Service Connect

Come producer di servizi, puoi utilizzare Private Service Connect per la pubblicazione che utilizzano indirizzi IP interni nella tua rete VPC. I servizi pubblicati sono accessibili ai consumer di servizi tramite indirizzi IP interni nelle reti VPC dei consumer.

Questa guida descrive come utilizzare Private Service Connect per pubblicare un servizio. Per pubblicare un servizio:

Private Service Connect fornisce due metodi per la connessione a Google Cloud:

Questi tipi di endpoint richiedono configurazioni del produttore leggermente diverse. Per maggiori informazioni, consulta Funzionalità e compatibilità.

Ruoli

Il seguente ruolo IAM fornisce le autorizzazioni necessarie per eseguire le attività descritte in questa guida.

Prima di iniziare

Crea un bilanciatore del carico supportato

Per ospitare il servizio, crea uno dei seguenti bilanciatori del carico in un servizio rete VPC del producer:

Per informazioni sulle configurazioni supportate per ciascun tipo di bilanciatore del carico, consulta Funzionalità e compatibilità.

Puoi associare ogni allegato del servizio alla regola di inoltro di un singolo bilanciatore del carico. Non puoi associare più collegamenti di servizi al la stessa regola di forwarding.

La versione IP della regola di forwarding del bilanciatore del carico (IPv4 o IPv6) influisce sui consumer che possono connettersi al servizio pubblicato. Per ulteriori informazioni, consulta Traduzione della versione IP.

Per i bilanciatori del carico di rete proxy interni regionali, i backend possono trovarsi in Google Cloud, in altri cloud, in un ambiente on-premise o qualsiasi combinazione di queste località.

Puoi anche pubblicare un servizio ospitato su un bilanciatore del carico della rete passthrough interno su Google Kubernetes Engine. Questa configurazione, inclusa la configurazione del bilanciatore del carico e del collegamento di servizio, è descritta in Creare un bilanciatore del carico di rete passthrough interno con Private Service Connect nella documentazione di GKE.

Creare una subnet per Private Service Connect

Crea una o più subnet dedicate da utilizzare con Private Service Connect. Se utilizzi la console Google Cloud per pubblicare un servizio, puoi creare le sottoreti durante la procedura.

Per rendere disponibili più indirizzi IP per un servizio esistente, consulta: Aggiungi o rimuovi subnet da un servizio pubblicato.

Puoi anche creare una subnet Private Service Connect in un progetto host VPC condiviso.

Crea la subnet nella stessa regione del bilanciatore del carico del servizio.

Non puoi convertire una subnet normale in Private Service Connect una subnet.

Se vuoi pubblicare un servizio che gestisce il traffico IPv6, devi utilizzare subnet dual-stack.

Console

  1. Nella console Google Cloud, vai alla pagina Reti VPC.

    Vai a Reti VPC

  2. Fai clic sul nome di una rete VPC per visualizzare la pagina Dettagli rete VPC.

  3. Fai clic su Subnet.

  4. Fai clic su Aggiungi subnet. Nel riquadro visualizzato:

    1. Fornisci un nome.
    2. Seleziona una Regione.
    3. Nella sezione Finalità, seleziona Private Service Connect.
    4. Seleziona un tipo di stack IP.
    5. Inserisci un intervallo IPv4. Ad esempio, 10.10.10.0/24.
    6. Fai clic su Aggiungi.

gcloud

gcloud compute networks subnets create SUBNET_NAME \
    --network=NETWORK_NAME \
    --region=REGION \
    --stack-type=STACK_TYPE \
    --range=SUBNET_RANGE \
    --purpose=PRIVATE_SERVICE_CONNECT

Sostituisci quanto segue:

  • SUBNET_NAME: il nome da assegnare alla una subnet.

  • NETWORK_NAME: il nome della VPC per la nuova subnet.

  • REGION: la regione per la nuova subnet. Deve essere della stessa regione del servizio che pubblichi.

  • STACK_TYPE: il tipo di stack della subnet, che può essere IPV4_ONLY o IPV4_IPV6. Il valore predefinito è IPV4_ONLY.

  • SUBNET_RANGE: l'intervallo di indirizzi IPv4 da utilizzare per una subnet, ad esempio 10.10.10.0/24.

API

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/subnetworks

{
  "ipCidrRange": "SUBNET_RANGE",
  "name": "SUBNET_NAME",
  "network": "projects/PROJECT_ID/global/networks/NETWORK_NAME",
  "purpose": "PRIVATE_SERVICE_CONNECT",
  "stackType": "STACK_TYPE"
}

Sostituisci quanto segue:

  • PROJECT_ID: il progetto per la subnet.

  • REGION: la regione della nuova subnet. Deve essere la stessa regione del servizio che stai pubblicando.

  • SUBNET_RANGE: l'intervallo di indirizzi IPv4 da utilizzare per una subnet. Ad esempio, 10.10.10.0/24.

  • SUBNET_NAME: il nome da assegnare alla sottorete.

  • NETWORK_NAME: il nome della rete VPC per la nuova subnet.

  • STACK_TYPE: il tipo di stack della subnet, che può essere IPV4_ONLY o IPV4_IPV6.

Configurazione delle regole del firewall

Configura le regole del firewall per consentire il traffico tra gli endpoint o i backend e l'attacco del servizio. Le richieste dei client provengono da posizioni diverse a seconda del tipo di Private Service Connect.

Tipo di Private Service Connect Intervalli di indirizzi IP per il traffico client Dettagli
Endpoint (basato su una regola di forwarding) Gli intervalli di indirizzi IP delle subnet Private Service Connect associati a questo servizio. Se utilizzi la rete predefinita, la regola precompilatadefault-allow-internal consente questo traffico, a meno che non sia presente una regola di priorità superiore che lo blocchi.
Backend (in base a Application Load Balancer esterno globale)
  • 130.211.0.0/22
  • 35.191.0.0/16
I bilanciatori del carico delle applicazioni esterni globali sono implementati sui Google Front End (GFE), che utilizzano da questi intervalli di indirizzi IP.

Se la configurazione del firewall non consente già il traffico dall'app tipo di endpoint, configura le regole firewall per consentirlo.

La configurazione di esempio seguente consente di creare regole firewall VPC per consenti il traffico dagli intervalli di indirizzi IP client alle VM di backend nel producer il bilanciatore del carico del servizio di emergenza. Questa configurazione presuppone che le VM di backend siano state configurate con una rete del tag.

Esempio di regola in entrata:

gcloud compute firewall-rules create NAME \
    --network=NETWORK_NAME \
    --direction=ingress \
    --action=allow \
    --target-tags=TAG \
    --source-ranges=CLIENT_IP_RANGES_LIST \
    --rules=RULES_LIST

Sostituisci quanto segue:

  • NAME: il nome della regola firewall.

  • NETWORK_NAME: la rete contenente il servizio e la subnet Private Service Connect.

  • TAG: il tag target applicato alle VM di backend nel bilanciatore del carico del servizio di produzione.

  • CLIENT_IP_RANGES_LIST: gli intervalli di indirizzi IP in cui il client da cui proviene il traffico. Per ulteriori informazioni, consulta la tabella precedente.

  • RULES_LIST: un elenco separato da virgole di protocolli e porte di destinazione a cui la regola . Ad esempio: tcp,udp.

Esempio di regola in uscita:

gcloud compute firewall-rules create NAME \
    --network=NETWORK_NAME \
    --direction=egress \
    --action=allow \
    --target-tags=TAG \
    --destination-ranges=CLIENT_IP_RANGES_LIST \
    --rules=RULES_LIST

Sostituisci quanto segue:

  • NAME: il nome della regola firewall.

  • NETWORK_NAME: la rete contenente il servizio e la subnet Private Service Connect.

  • TAG: il tag target applicato alle VM di backend nel bilanciatore del carico del servizio di produzione.

  • CLIENT_IP_RANGES_LIST: gli intervalli di indirizzi IP in cui il client da cui proviene il traffico. Per ulteriori informazioni, consulta la tabella precedente.

  • RULES_LIST: un elenco separato da virgole di protocolli e porte di destinazione a cui si applica la regola. Ad esempio: tcp,udp.

Per ulteriori informazioni sulla configurazione delle regole firewall VPC, consulta Regole firewall VPC. Per configurare la gerarchia le regole firewall per consentire questo traffico, vedi Criteri firewall gerarchici.

Pubblicare un servizio

Per pubblicare un servizio, devi creare un collegamento al servizio. Puoi rendere il servizio disponibile in uno dei due seguenti modi:

Crea il collegamento al servizio nella stessa regione del carico del servizio con il bilanciatore del carico di rete passthrough esterno regionale.

Ogni collegamento al servizio può puntare a una o più subnet Private Service Connect, ma una subnet Private Service Connect non può essere utilizzata in più di un collegamento al servizio.

Pubblicare un servizio con approvazione automatica

Segui queste istruzioni per pubblicare un servizio e consentire automaticamente a qualsiasi consumatore di connettersi a questo servizio. Se vuoi approvare esplicitamente le connessioni dei consumatori, consulta la sezione sulla pubblicazione di un servizio con approvazione esplicita.

Quando pubblichi un servizio, ne crei il collegamento. Consumer dei servizi utilizzare i dettagli del collegamento al servizio per connetterti al tuo servizio.

Se vuoi visualizzare le informazioni di connessione dei consumer, puoi attivare il protocollo PROXY sui servizi supportati. Per informazioni sui servizi supportati, vedi Funzionalità e compatibilità. Per Per ulteriori informazioni sul protocollo PROXY, consulta Connessione consumer. informazioni.

Puoi associare subnet single-stack e dual-stack allo stesso collegamento al servizio. Se il bilanciatore del carico è configurato per il traffico IPv6, devi utilizzare subnet a doppio stack.

Quando pubblichi un servizio con approvazione automatica, il limite per le connessioni propagate si applica a ogni progetto consumer che si connette al collegamento al servizio.

Console

  1. Nella console Google Cloud, vai alla pagina Private Service Connect.

    Vai a Private Service Connect

  2. Fai clic sulla scheda Servizi pubblicati.

  3. Fai clic su Pubblica servizio.

  4. Seleziona il Tipo di bilanciatore del carico per il servizio che vuoi pubblicare:

    • Bilanciatore del carico di rete passthrough interno
    • Bilanciatore del carico di rete proxy interno regionale
    • Bilanciatore del carico delle applicazioni interno regionale
  5. Seleziona il bilanciatore del carico interno che ospita il servizio che vuoi pubblicare. I campi relativi a rete e regione vengono compilati con per il bilanciatore del carico interno selezionato.

    Amministratori progetti di servizio puoi selezionare un bilanciatore del carico interno che abbia un indirizzo IP da un Rete VPC condivisa. Per maggiori informazioni, vedi VPC condiviso.

  6. Se richiesto, seleziona la Regola di forwarding associata al che vuoi pubblicare.

  7. In Nome servizio, inserisci un nome per il collegamento del servizio.

  8. Seleziona una o più subnet di Private Service Connect per il servizio. L'elenco viene compilato con le subnet della rete VPC dell'equilibratore del carico interno selezionato, incluse le subnet condivise con un progetto di servizio tramite VPC condiviso.

    Se il collegamento al servizio utilizza un bilanciatore del carico interno con un indirizzo IP da una rete VPC condiviso, devi selezionare un dalla stessa rete VPC condiviso.

    Se vuoi aggiungere una nuova subnet, puoi crearne una:

    1. Fai clic su Prenota nuova subnet
    2. Inserisci un Nome e una Descrizione facoltativa per la subnet.
    3. Seleziona una regione per la subnet.
    4. Seleziona un tipo di stack IP.
    5. Inserisci l'intervallo IPv4 da utilizzare per la subnet e fai clic su Aggiungi.
  9. Se vuoi visualizzare le informazioni di connessione dei consumatori, seleziona Utilizza protocollo proxy.

  10. Seleziona Accetta automaticamente tutte le connessioni.

  11. Se vuoi disattivare la riconciliazione delle connessioni, deseleziona la casella di controllo Attiva riconciliazione delle connessioni.

  12. (Facoltativo) Fai clic su Configurazione avanzata, quindi:

    1. Se vuoi configurare un nome di dominio, inserisci un Nome di dominio, incluso un punto finale.

      Il formato consigliato per il nome di dominio è REGION.p.DOMAIN.

      Il nome del dominio deve essere di tua proprietà. Per ulteriori informazioni, consulta la sezione Configurazione DNS.

    2. Inserisci un limite di connessioni NCC propagate. Se non specificato, il valore predefinito è 250.

  13. Fai clic su Aggiungi servizio.

gcloud

gcloud compute service-attachments create ATTACHMENT_NAME \
    --region=REGION \
    --producer-forwarding-rule=RULE_NAME \
    --connection-preference=ACCEPT_AUTOMATIC \
    --nat-subnets=PSC_SUBNET_LIST \
    [ --propagated-connection-limit=PROPAGATED_CONNECTION_LIMIT ] \
    [ --enable-proxy-protocol ] \
    [ --domain-names=DOMAIN_NAME ]

Sostituisci quanto segue:

  • ATTACHMENT_NAME: il nome da assegnare alla collegamento del servizio.

  • REGION: la regione per il collegamento del nuovo servizio. Deve essere la stessa regione del servizio che stai pubblicando.

  • RULE_NAME: il nome della regola di forwarding che è associati al servizio che pubblichi.

    Amministratori progetti di servizio puoi specificare la regola di forwarding di un bilanciatore del carico interno che da un Rete VPC condivisa. Per maggiori informazioni, vedi VPC condiviso.

  • PSC_SUBNET_LIST: un elenco separato da virgole di uno o più nomi di sottoreti da utilizzare con questo allegato del servizio.

    Se crei un servizio collegamento con una regola di forwarding che ha un indirizzo IP da un una rete VPC condiviso, usa subnet condivise Rete VPC condiviso. Per ogni subnet condivisa, specifica l'URI della risorsa completa, ad esempio --nat-subnets=projects/PROJECT_ID/regions/REGION/subnetworks/SUBNET.

  • PROPAGATED_CONNECTION_LIMIT: il valore per progetto limite di connessioni propagate. Il valore predefinito è 250.

  • DOMAIN_NAME: un nome di dominio DNS per il servizio, incluso un punto finale. Formato consigliato: REGION.p.DOMAIN.

    Per ulteriori informazioni, consulta la sezione Configurazione DNS.

API

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/serviceAttachments
{
  "name": "ATTACHMENT_NAME",
  "connectionPreference": "ACCEPT_AUTOMATIC",
  "targetService": "RULE_URI",
  "enableProxyProtocol": false,
  "natSubnets": [
    "PSC_SUBNET_1_URI",
    "PSC_SUBNET_2_URI"
  ],
  "propagatedConnectionLimit": "PROPAGATED_CONNECTION_LIMIT",
  "domainNames": [
    "DOMAIN_NAME"
  ]
}

Sostituisci quanto segue:

  • PROJECT_ID: il progetto per il collegamento al servizio.

  • REGION: la regione per il collegamento del nuovo servizio. Deve essere la stessa regione del servizio che stai pubblicando.

  • ATTACHMENT_NAME: il nome da assegnare alla collegamento del servizio.

  • RULE_URI: l'URI della regola di forwarding associati al servizio che stai pubblicando.

    Gli amministratori dei progetti di servizi possono specificare la regola di inoltro di un bilanciatore del carico interno con un indirizzo IP di una rete VPC condivisa. Per maggiori informazioni, vedi VPC condiviso.

  • PSC_SUBNET_1_URI e PSC_SUBNET_2_URI: gli URI della subnet da utilizzare per il collegamento al servizio. Puoi specificare una o più subnet tramite URI.

    Se crei un servizio collegamento con una regola di forwarding che ha un indirizzo IP da un una rete VPC condiviso, usa subnet condivise Rete VPC condiviso.

  • DOMAIN_NAME: un nome di dominio DNS per il servizio, incluso un punto finale. Formato consigliato: REGION.p.DOMAIN.

    Per ulteriori informazioni, vedi Configurazione DNS.

  • PROPAGATED_CONNECTION_LIMIT: il limite di connessioni propagate per progetto. Il valore predefinito è 250.

Pubblicare un servizio con approvazione esplicita

Segui queste istruzioni per pubblicare un servizio se vuoi approvare esplicitamente i consumatori prima che possano connettersi a questo servizio. Se vuoi approvare per le connessioni con i consumatori, consulta la sezione sulla pubblicazione di un servizio con approvazione.

Quando pubblichi un servizio, crei un collegamento a un servizio. I consumatori di servizi utilizzano i dettagli del collegamento del servizio per connettersi al tuo servizio.

Ogni collegamento al servizio ha un liste di accettazione dei consumatori e una lista rifiutata dei consumatori, che vengono utilizzati per determinare quali endpoint possono connettersi al servizio. Un determinato collegamento al servizio può utilizzare progetti o emittenti in questi elenchi, ma non entrambi. La specifica dei consumer per cartella non è supportata.

Se passi dall'accettazione dei consumatori in base al progetto all'accettazione dei consumatori in base al progetto in base alla rete o viceversa, procedi nel seguente modo:

  • Sostituisci tutte le reti o tutti i progetti approvati in un'unica operazione.
  • Se devi fornire lo stesso accesso di prima, assicurati che il nuovo le liste di accettazione e rifiuto sono equivalenti ai precedenti.

Se aggiungi un progetto o una rete sia all'elenco di accettazione che a quello di rifiuto, richieste di connessione provenienti dal progetto o dalla rete vengono rifiutate.

Se gli elenchi di accettazione e rifiuto dei consumer fanno riferimento a progetti, il limite di connessioni propagato si applica ai progetti consumer. Se il consumatore accetta e gli elenchi di contenuti rifiutati si riferiscono a reti VPC, la connessione propagata si applica alle reti VPC consumer.

Console

  1. Nella console Google Cloud, vai alla pagina Private Service Connect.

    Vai a Private Service Connect

  2. Fai clic sulla scheda Servizi pubblicati.

  3. Fai clic su Pubblica servizio.

  4. Seleziona il Tipo di bilanciatore del carico per il servizio che vuoi pubblicare:

    • Bilanciatore del carico di rete passthrough interno
    • Bilanciatore del carico di rete proxy interno regionale
    • Bilanciatore del carico delle applicazioni interno regionale
  5. Seleziona il bilanciatore del carico interno che ospita il servizio che che vuoi pubblicare. I campi relativi a rete e regione vengono compilati con per il bilanciatore del carico interno selezionato.

    Gli amministratori dei progetti di servizio possono selezionare un bilanciatore del carico interno con un indirizzo IP di una rete VPC condivisa. Per maggiori informazioni, vedi VPC condiviso.

  6. Se richiesto, seleziona la regola di forwarding associata al servizio che vuoi pubblicare.

  7. In Nome servizio, inserisci un nome per il collegamento del servizio.

  8. Seleziona una o più subnet di Private Service Connect per il servizio. L'elenco viene compilato con le subnet della rete VPC dell'equilibratore del carico interno selezionato, incluse le subnet condivise con un progetto di servizio tramite VPC condiviso.

    Se il collegamento al servizio utilizza un bilanciatore del carico interno con un indirizzo IP da una rete VPC condiviso, devi selezionare un dalla stessa rete VPC condiviso.

    Se vuoi aggiungere una nuova subnet, puoi crearne una:

    1. Fai clic su Prenota nuova subnet
    2. Inserisci un Nome e una Descrizione facoltativa per la subnet.
    3. Seleziona una Regione per la subnet.
    4. Seleziona un tipo di stack IP.
    5. Inserisci l'intervallo IPv4 da utilizzare per la subnet e fai clic su Aggiungi.
  9. Se desideri visualizzare le informazioni sulla connessione del consumer, seleziona Utilizza proxy Protocollo.

  10. Se vuoi accettare le connessioni per i progetti selezionati, seleziona Accetta connessioni per i progetti selezionati.

    1. Per ogni progetto da cui vuoi accettare connessioni, esegui questa seguenti:
      1. Fai clic su Aggiungi progetto accettato, quindi inserisci quanto segue:
        • L'ID o il numero del progetto da cui vuoi accettare le connessioni.
        • Un limite di connessioni per specificare il numero massimo. di endpoint del progetto specificato che possono connettersi.
    2. (Facoltativo) Per ogni progetto da cui vuoi rifiutare esplicitamente le connessioni, fai clic su Aggiungi progetto rifiutato e inserisci l'ID o il numero del progetto.
  11. Se vuoi accettare connessioni per le reti selezionate, seleziona Accetta connessioni per le reti selezionate.

    1. Per ogni emittente da cui vuoi accettare le connessioni, procedi nel seguente modo:
      1. Fai clic su Aggiungi rete accettata, quindi inserisci quanto segue:
        • L'ID o il numero del progetto padre della rete da cui vuoi accettare le connessioni.
        • Il nome della rete su cui vuoi accettare connessioni da cui proviene.
        • Un limite di connessioni per specificare il numero massimo. di endpoint dalla rete specificata che possono connettersi.
    2. (Facoltativo) Per ogni rete che vuoi rifiutare esplicitamente connessioni da, fai clic su Aggiungi rete rifiutata, quindi inserisci l'ID o il numero del progetto principale della rete e il nome della rete.
  12. Se vuoi disattivare la riconciliazione della connessione, cancella il contenuto della sezione Casella di controllo Abilita riconciliazione connessioni.

  13. (Facoltativo) Fai clic su Configurazione avanzata, quindi:

    1. Se vuoi configurare un nome di dominio, inserisci un Nome di dominio, incluso un punto finale.

      Il formato consigliato per il nome di dominio è REGION.p.DOMAIN.

      Il nome del dominio deve essere di tua proprietà. Per ulteriori informazioni, vedi Configurazione DNS.

    2. Inserisci un limite per le connessioni NCC propagate. Se non specificato, il valore predefinito è 250.

  14. Fai clic su Aggiungi servizio.

gcloud

gcloud compute service-attachments create ATTACHMENT_NAME \
    --region=REGION \
    --producer-forwarding-rule=RULE_NAME \
    --connection-preference=ACCEPT_MANUAL \
    --consumer-accept-list=ACCEPTED_PROJECT_OR_NETWORK_1=LIMIT_1,ACCEPTED_PROJECT_OR_NETWORK_2=LIMIT_2 \
    --consumer-reject-list=REJECTED_PROJECT_OR_NETWORK_1,REJECTED_PROJECT_OR_NETWORK_2 \
    --nat-subnets=PSC_SUBNET_LIST \
    [ --propagated-connection-limit=PROPAGATED_CONNECTION_LIMIT ] \
    [ --enable-proxy-protocol ] \
    [ --domain-names=DOMAIN_NAME ] \
    [ --reconcile-connections ]

Sostituisci quanto segue:

  • ATTACHMENT_NAME: il nome da assegnare alla collegamento del servizio.

  • REGION: la regione per il collegamento del nuovo servizio. Deve essere la stessa regione del servizio che stai pubblicando.

  • RULE_NAME: il nome della regola di inoltro associata al servizio che stai pubblicando.

    Amministratori progetti di servizio puoi specificare la regola di forwarding di un bilanciatore del carico interno che da un Rete VPC condivisa. Per maggiori informazioni, vedi VPC condiviso.

  • ACCEPTED_PROJECT_OR_NETWORK_1 e ACCEPTED_PROJECT_OR_NETWORK_2: gli ID progetto, o URI di rete da accettare. --consumer-accept-list è facoltativo e può contenere uno o più progetti o reti, ma non una combinazione di entrambi i tipi.

  • LIMIT_1 e LIMIT_2: la connessione per i progetti o le reti. Il limite di connessione è il numero di endpoint o backend consumer che possono connettersi a questo servizio. Ogni progetto o rete accettato deve avere un limite di connessioni configurato.

  • REJECTED_PROJECT_OR_NETWORK_1 e REJECTED_PROJECT_OR_NETWORK_2: gli ID progetto, i nomi progetto o gli URI di rete da rifiutare. --consumer-reject-list è facoltativo e può contenere uno o più progetti o reti, ma non una combinazione di entrambi i tipi.

  • PSC_SUBNET_LIST: un elenco di uno o più contenuti separati da virgole i nomi delle subnet da usare con il collegamento a questo servizio.

    Se crei un servizio collegamento con una regola di forwarding che ha un indirizzo IP da un una rete VPC condiviso, usa subnet condivise Rete VPC condiviso. Per ogni subnet condivisa, specifica URI risorsa, ad esempio --nat-subnets=projects/PROJECT_ID/regions/REGION/subnetworks/SUBNET.

  • PROPAGATED_CONNECTION_LIMIT: il limite di connessioni propagate. Il valore predefinito è 250.

  • DOMAIN_NAME: un nome di dominio DNS per il servizio, incluso un punto finale. Formato consigliato: REGION.p.DOMAIN.

    Per ulteriori informazioni, consulta la sezione Configurazione DNS.

API

  • Per pubblicare un servizio e approvare esplicitamente i consumatori in base al progetto, invia la seguente richiesta:

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/serviceAttachments
    {
      "name": "ATTACHMENT_NAME",
      "region": "REGION",
      "connectionPreference": "ACCEPT_MANUAL",
      "targetService": "RULE_URI",
      "enableProxyProtocol": false,
      "natSubnets": [
        "PSC_SUBNET_1_URI",
        "PSC_SUBNET_2_URI"
      ],
      "consumerRejectLists": [
        "REJECTED_PROJECT_1",
        "REJECTED_PROJECT_2"
      ],
      "consumerAcceptLists": [
        {
          "projectIdOrNum": "ACCEPTED_PROJECT_1",
          "connectionLimit": "LIMIT_1"
        },
        {
          "projectIdOrNum": "ACCEPTED_PROJECT_2",
          "connectionLimit": "LIMIT_2"
        }
      ],
      "propagatedConnectionLimit": "PROPAGATED_CONNECTION_LIMIT",
      "domainNames": [
        "DOMAIN_NAME"
      ]
    }
    

    Sostituisci quanto segue:

    • PROJECT_ID: il progetto per il collegamento del servizio.

    • REGION: la regione per il collegamento al servizio.

    • ATTACHMENT_NAME: il nome da assegnare alla collegamento del servizio.

    • RULE_URI: l'URI della regola di inoltro associata al servizio che stai pubblicando.

      Gli amministratori dei progetti di servizi possono specificare la regola di inoltro di un bilanciatore del carico interno con un indirizzo IP di una rete VPC condivisa. Per maggiori informazioni, vedi VPC condiviso.

    • PSC_SUBNET_1_URI e PSC_SUBNET_2_URI: gli URI delle subnet da utilizzare per questo collegamento a un servizio. Puoi specificare una o più subnet tramite URI.

      Se stai creando un aggancio di servizio con una regola di inoltro che ha un indirizzo IP di una rete VPC condivisa, utilizza le subnet condivise della stessa rete VPC condivisa.

    • REJECTED_PROJECT_1 e REJECTED_PROJECT_2: gli ID o i numeri dei progetti progetti da rifiutare. consumerRejectLists è facoltativo e può contenere per uno o più progetti.

    • ACCEPTED_PROJECT_1 e ACCEPTED_PROJECT_2: gli ID o i numeri del progetto progetti da accettare. consumerAcceptLists è facoltativo e può contenere per uno o più progetti.

    • LIMIT_1 e LIMIT_2: il valore di connessione per progetti. Il limite di connessione è il numero di endpoint o backend dei consumer che possono connettersi a questo servizio. Per ogni progetto accettato deve essere configurato un limite di connessione.

    • DOMAIN_NAME: un nome di dominio DNS per il servizio, incluso un punto finale. Formato consigliato: REGION.p.DOMAIN. Per ulteriori informazioni, consulta Configurazione DNS.
  • Per pubblicare un servizio e approvare esplicitamente i consumer in base alla rete VPC, invia la seguente richiesta:

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/serviceAttachments
    {
      "name": "ATTACHMENT_NAME",
      "region": "REGION",
      "connectionPreference": "ACCEPT_MANUAL",
      "targetService": "RULE_URI",
      "enableProxyProtocol": false,
      "natSubnets": [
        "PSC_SUBNET_1_URI",
        "PSC_SUBNET_2_URI"
      ],
      "consumerRejectLists": [
        "projects/REJECTED_PROJECT_ID_1/global/networks/REJECTED_NETWORK_1",
        "projects/REJECTED_PROJECT_ID_2/global/networks/REJECTED_NETWORK_2"
      ],
      "consumerAcceptLists": [
        {
          "networkUrl": "projects/ACCEPTED_PROJECT_ID_1/global/networks/ACCEPTED_NETWORK_1",
          "connectionLimit": "LIMIT_1"
        },
        {
          "networkUrl": "projects/ACCEPTED_PROJECT_ID_2/global/networks/ACCEPTED_NETWORK_2",
          "connectionLimit": "LIMIT_2"
        }
      ],
      "propagatedConnectionLimit": PROPAGATED_CONNECTION_LIMIT,
      "domainNames": [
        "DOMAIN_NAME"
      ]
    }
    

    Sostituisci quanto segue:

    • REJECTED_PROJECT_ID_1 e REJECTED_PROJECT_ID_2: gli ID dei progetti padre reti che vuoi rifiutare. consumerRejectLists è facoltativo e può contenere una o più reti.
    • REJECTED_NETWORK_1 e REJECTED_NETWORK_2: i nomi delle reti che vuoi rifiutare.
    • ACCEPTED_PROJECT_ID_1 e ACCEPTED_PROJECT_ID_2: gli ID dei progetti padre dalle reti che vuoi accettare. consumerAcceptLists è facoltativo e può contenere una o più reti.
    • ACCEPTED_NETWORK_1 e ACCEPTED_NETWORK_2: i nomi delle emittenti che vuoi accettare.
    • LIMIT_1 e LIMIT_2: i limiti di connessione per le reti. Il limite di connessione è il numero di endpoint o backend dei consumer che possono connettersi a questo servizio. Per ogni progetto accettato deve essere configurato un limite di connessioni.
    • DOMAIN_NAME: un nome di dominio DNS per il servizio, incluso un punto finale. Formato consigliato: REGION.p.DOMAIN. Per ulteriori informazioni, vedi Configurazione DNS.
  • Per pubblicare un servizio con la riconciliazione delle connessioni abilitata, invia un simile alle richieste precedenti, ma che includono il campo campo seguente:

    {
      ...
      "reconcileConnections": true
      ...
    }
    

Visualizzare le informazioni di connessione del consumer

Per informazioni sulla visualizzazione delle informazioni sulla connessione del consumatore utilizzando sul protocollo PROXY, consulta la sezione Visualizzazione delle informazioni di connessione dei consumatori.

Gestire le richieste di accesso a un servizio pubblicato

Se hai un servizio pubblicato con approvazione esplicita, puoi accettare o rifiutare le richieste di connessione da progetti o reti di consumatori. Per ulteriori informazioni, vedi Gestire le richieste di accesso a un servizio pubblicato.

Puoi anche passare dall'accettazione automatica a quella esplicita del progetto per un completamente gestito di Google Cloud. Per ulteriori informazioni, vedi Modificare la preferenza di connessione per un servizio pubblicato

Aggiungere o rimuovere sottoreti da un servizio pubblicato

Puoi aggiungere o rimuovere subnet da un servizio pubblicato. Per ulteriori informazioni, consulta Aggiungere o rimuovere subnet da un servizio pubblicato.

Elenca i servizi pubblicati

Puoi elencare tutti i servizi.

Console

  1. Nella console Google Cloud, vai alla pagina Private Service Connect.

    Vai a Private Service Connect

  2. Fai clic sulla scheda Servizi pubblicati.

    I collegamenti del servizio Private Service Connect sono visualizzati.

gcloud

  1. Elenca i collegamenti di servizi.

    gcloud compute service-attachments list [--regions=REGION_LIST]
    

    Sostituisci quanto segue:

    • REGION_LIST: un elenco separato da virgole di una o più regioni per le quali vuoi visualizzare gli allegati del servizio. Ad esempio, us-central1 o us-west1,us-central1.

API

Puoi visualizzare tutti i collegamenti dei servizi in una determinata regione o in tutte le regioni.

  • Visualizza tutti gli allegati dei servizi in una regione:

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/serviceAttachments
    
  • Visualizza tutti gli allegati dei servizi in tutte le regioni:

    GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/aggregated/serviceAttachments
    

    Sostituisci quanto segue:

    • PROJECT_ID: il progetto per il collegamento del servizio.

    • REGION: la regione per il collegamento al servizio.

    • ATTACHMENT_NAME: il nome del collegamento a servizio.

Visualizzare i dettagli di un servizio pubblicato

Puoi visualizzare i dettagli di configurazione di un servizio pubblicato. Puoi visualizzare alcuni dettagli di configurazione nella console Google Cloud, ad esempio l'URI di allegato del servizio di cui i consumatori del servizio hanno bisogno per connettersi al tuo servizio. Per visualizzare tutti i dettagli, inclusi i valori pscConnectionId per i consumatori dell'allegato del servizio, utilizza Google Cloud CLI o l'API.

Console

Puoi visualizzare i dettagli di un servizio pubblicato. Il campo Collegamento servizio contiene l'URI del collegamento al servizio.

  1. Nella console Google Cloud, vai alla pagina Private Service Connect.

    Vai a Private Service Connect

  2. Fai clic sulla scheda Servizi pubblicati.

  3. Fai clic sul servizio che vuoi visualizzare.

gcloud

Puoi visualizzare i dettagli di un servizio pubblicato. Il campo selfLink contiene l'URI del collegamento al servizio.

gcloud compute service-attachments describe \
    ATTACHMENT_NAME --region=REGION

API

Puoi visualizzare i dettagli di un servizio pubblicato. Il campo selfLink contiene l'URI del collegamento al servizio.

GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/serviceAttachments/ATTACHMENT_NAME

Sostituisci quanto segue:

  • PROJECT_ID: il progetto per il collegamento del servizio.

  • REGION: la regione per il collegamento al servizio.

  • ATTACHMENT_NAME: il nome del collegamento a servizio.

Elimina un servizio pubblicato

Puoi eliminare un servizio pubblicato, anche se sono presenti al collegamento del servizio. L'eliminazione del servizio pubblicato rimuove solo l'allegato del servizio. Il bilanciatore del carico associato non è eliminati. Quando elimini un servizio pubblicato, si applica quanto segue:

Console

  1. Nella console Google Cloud, vai alla pagina Private Service Connect.

    Vai a Private Service Connect

  2. Fai clic sulla scheda Servizi pubblicati.

  3. Fai clic sul servizio che vuoi eliminare.

  4. Fai clic su Elimina.

gcloud

gcloud compute service-attachments delete \
    ATTACHMENT_NAME --region=REGION

API

DELETE https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/serviceAttachments/ATTACHMENT_NAME

Sostituisci quanto segue:

  • PROJECT_ID: il progetto per il collegamento del servizio.

  • REGION: la regione per il collegamento al servizio.

  • ATTACHMENT_NAME: il nome del collegamento a servizio.

Problemi noti

Disconnessioni dopo l'upgrade del provider Google per Terraform

Se hai utilizzato il provider Google per Terraform con versioni precedenti a 4.76.0 per creare collegamenti ai servizi, non eseguire l'upgrade alle versioni dalla 4.76.0 alla 4.81.x. Quando esegui terraform apply dopo l'upgrade alle versioni 4.76.0 fino alla 4.81.x, Terraform potrebbe eliminare e ricreare involontariamente i collegamenti del servizio e chiudere le connessioni Private Service Connect esistenti. I collegamenti dei servizi ricreati non ristabiliscono automaticamente le connessioni di Private Service Connect.

Se esegui l'upgrade alla versione 4.82.0 ed esegui terraform apply, gli allegati dei servizi non vengono eliminati, ma l'impostazione reconcile connections è impostata su true. Se l'impostazione era precedentemente impostata su false, alcune Le connessioni Private Service Connect potrebbero chiudersi.

  • Upgrade al provider Google dalle versioni dalla 4.76.0 alla 4.81.x. In questo scenario, l'output di terraform plan include quanto segue:

    -/+ resource "google_compute_service_attachment" "SERVICE_NAME" {
      ...
            ~ reconcile_connections = false -> true # forces replacement
      ...
    

    Utilizza la soluzione alternativa per evitare questo problema.

  • Upgrade alle versioni del fornitore Google 4.82.0. In questo scenario, il risultato di terraform plan include quanto segue:

    ~ reconcile_connections = false -> true
    

    Se ignori questo avviso e applichi le modifiche, Terraform aggiorna l'aggancio del servizio per attivare la riconciliazione delle connessioni. A seconda dello stato della connessione, il passaggio da false a true potrebbe comportare la chiusura di alcune connessioni esistenti. Per ulteriori informazioni, consulta la sezione Connessione riconciliazione.

    Utilizza la soluzione alternativa per evitare questo problema.

Soluzione alternativa

Ti consigliamo di eseguire l'upgrade del provider Google per Terraform alla versione 4.82.0 o successiva. Questa versione impedisce l'eliminazione e la ricreazione involontaria del servizio allegati.

Se non puoi eseguire l'upgrade immediatamente o se vuoi eseguire l'upgrade impedire a Terraform di modificare l'impostazione di riconciliazione della connessione, aggiornare della configurazione Terraform per impostare esplicitamente la riconciliazione della connessione dell'ambientazione.

  1. Visualizza la configurazione dettagliata del collegamento al servizio e prendi nota Impostazione reconcileConnections.

    $ gcloud compute service-attachments describe SERVICE_NAME --region=REGION
    

    L'output include il campo reconcileConnections, che può essere true o false.

    reconcileConnections: false
    
  2. Aggiorna il file di configurazione Terraform per utilizzare in modo esplicito la stessa impostazione usato nel collegamento al servizio.

    resource "google_compute_service_attachment" "SERVICE_NAME" {
      ...
      reconcile_connections    = false
    }
    

    Per una configurazione di esempio, consulta Connessioni per la riconciliazione dei collegamenti degli allegati dei servizi su GitHub.

Aggiornamenti delle patch per i collegamenti ai servizi

Quando aggiorni un allegato del servizio utilizzando l'API PATCH, devi fornire tutti i campi per l'allegato del servizio nel corpo della richiesta, non solo i campi che stai aggiornando. Utilizza le funzionalità di serviceAttachments.get per recuperare tutti i campi.

Risoluzione dei problemi

Errore durante l'aggiornamento di un allegato del servizio

Se viene visualizzato il seguente messaggio di errore quando aggiorni il collegamento a un servizio, Accetta o l'elenco degli elementi da rifiutare potrebbe includere progetti eliminati: The resource PROJECT was not found.

Rimuovi i progetti eliminati dalla configurazione dell'attacco al servizio per risolvere il problema.

  1. Usa il comando gcloud compute service-attachments describe per visualizzare del collegamento al servizio che vuoi modificare.

    • Per generare l'elenco di accettazione in un formato da utilizzare in un secondo momento per aggiornare il collegamento a un servizio, segui questi passaggi:

      gcloud compute service-attachments describe ATTACHMENT_NAME \
        --region=REGION --flatten="consumerAcceptLists[]" \
        --format="csv[no-heading,separator='='](consumerAcceptLists.projectIdOrNum,consumerAcceptLists.connectionLimit)" \
        | xargs | sed -e 's/ /,/g'
      

      L'output della lista di accettazione è simile al seguente:

      PROJECT_1=LIMIT_1,PROJECT_2=LIMIT_2,PROJECT_3=LIMIT_3
      
    • Per generare l'elenco di rifiuto in un formato che puoi utilizzare in un secondo momento per aggiornare l'allegato del servizio:

      gcloud compute service-attachments describe ATTACHMENT_NAME \
        --region=REGION \
        --format="value[delimiter=','](consumerRejectLists[])"
      

      L'output dell'elenco di elementi rifiutati è simile al seguente:

      PROJECT_1,PROJECT_2,PROJECT_3
      
  2. Modifica l'output del comando per rimuovere eventuali progetti eliminati dall'elenco di accettazione e dall'elenco di rifiuto.

  3. Aggiorna il collegamento del servizio per rimuovere i progetti eliminati.

    • Per aggiornare l'elenco di accettazione, procedi nel seguente modo:

      gcloud compute service-attachments update ATTACHMENT_NAME \
        --region=REGION \
        --consumer-accept-list=UPDATED_ACCEPT_LIST
      
    • Per aggiornare l'elenco di elementi rifiutati, procedi nel seguente modo:

      gcloud compute service-attachments update ATTACHMENT_NAME \
        --region=REGION \
        --consumer-reject-list=UPDATED_REJECT_LIST
      

La connettività non è stabilita

Se un consumatore ha creato un endpoint o un backend che fa riferimento al tuo allegato del servizio, ma la connettività non è stabilita, controlla lo stato della connessione dell'allegato del servizio. Lo stato della connessione potrebbe indicare i passaggi da seguire per risolvere il problema.

Timeout delle connessioni con i consumatori

Se le connessioni dei consumatori scadono, controlla se il tuo servizio richiede connessioni di lunga durata. Timeout di inattività della connessione stabilita TCP per La durata di Private Service Connect NAT è di 20 minuti. Se il tuo servizio richiede un tempo di attesa più lungo, potresti dover apportare alcune modifiche di configurazione per assicurarti che le connessioni non scadano. Per ulteriori informazioni, consulta le specifiche NAT.

Le connessioni propagate non sono stabilite

Per informazioni sulla risoluzione dei problemi relativi alle connessioni propagate, consulta Risolvi i problemi di Network Connectivity Center.