Pubblica e ricevi messaggi in Pub/Sub utilizzando una libreria client
Il servizio Pub/Sub consente alle applicazioni di scambiare messaggi in modo affidabile, rapido e asincrono. Di seguito è riportata la sequenza di eventi:
- Un produttore di dati pubblica un messaggio in un argomento Pub/Sub.
- Un client sottoscrittore crea una sottoscrizione all'argomento e utilizza i messaggi della sottoscrizione.
Puoi configurare un ambiente Pub/Sub utilizzando uno dei seguenti metodi:console Google Cloud , Cloud Shell, librerie client o API REST. Questa pagina mostra come iniziare a pubblicare messaggi con Pub/Sub utilizzando le librerie client.
Pub/Sub offre una libreria client di alto e basso livello generata automaticamente. Per impostazione predefinita, come in questa guida rapida, consigliamo la libreria client di alto livello.
Per seguire le indicazioni dettagliate per questa attività direttamente nella Google Cloud console, fai clic su Procedura guidata:
Prima di iniziare
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
      Install the Google Cloud CLI. 
- 
          Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata. 
- 
        Per inizializzare gcloud CLI, esegui questo comando: gcloud init
- 
  
  
    Create or select a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 - 
        Create a Google Cloud project: gcloud projects create PROJECT_ID Replace PROJECT_IDwith a name for the Google Cloud project you are creating.
- 
        Select the Google Cloud project that you created: gcloud config set project PROJECT_ID Replace PROJECT_IDwith your Google Cloud project name.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Pub/Sub API: Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.gcloud services enable pubsub.googleapis.com 
- 
  
      Create local authentication credentials for your user account: gcloud auth application-default login If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. 
- 
    
        Grant roles to your user account. Run the following command once for each of the following IAM roles: roles/pubsub.admingcloud projects add-iam-policy-binding PROJECT_ID --member="user:USER_IDENTIFIER" --role=ROLE Replace the following: - PROJECT_ID: Your project ID.
- USER_IDENTIFIER: The identifier for your user account. For example,- myemail@example.com.
- ROLE: The IAM role that you grant to your user account.
 
- 
      Install the Google Cloud CLI. 
- 
          Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata. 
- 
        Per inizializzare gcloud CLI, esegui questo comando: gcloud init
- 
  
  
    Create or select a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 - 
        Create a Google Cloud project: gcloud projects create PROJECT_ID Replace PROJECT_IDwith a name for the Google Cloud project you are creating.
- 
        Select the Google Cloud project that you created: gcloud config set project PROJECT_ID Replace PROJECT_IDwith your Google Cloud project name.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Pub/Sub API: Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.gcloud services enable pubsub.googleapis.com 
- 
  
      Create local authentication credentials for your user account: gcloud auth application-default login If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. 
- 
    
        Grant roles to your user account. Run the following command once for each of the following IAM roles: roles/pubsub.admingcloud projects add-iam-policy-binding PROJECT_ID --member="user:USER_IDENTIFIER" --role=ROLE Replace the following: - PROJECT_ID: Your project ID.
- USER_IDENTIFIER: The identifier for your user account. For example,- myemail@example.com.
- ROLE: The IAM role that you grant to your user account.
 
- Per evitare che al tuo account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questa guida, puoi utilizzare la riga di comando per eliminare l'argomento e l'abbonamento.
gcloud pubsub subscriptions delete my-sub gcloud pubsub topics delete my-topic 
- 
  
      Optional: Revoke the authentication credentials that you created, and delete the local credential file. gcloud auth application-default revoke 
- 
  
      Optional: Revoke credentials from the gcloud CLI. gcloud auth revoke 
- Scopri di più sui concetti Pub/Sub trattati in questa pagina. 
- Leggi le nozioni di base sul servizio Pub/Sub. 
- Scopri come creare un sistema Pub/Sub uno-a-molti, che crea un'applicazione publisher che pubblica su due applicazioni abbonate separate. 
- Prova un'altra guida rapida di Pub/Sub che utilizza gcloud CLI o la console. 
- Scopri di più sulle API Pub/Sub. 
- Scopri come eseguire Pub/Sub utilizzando Kotlin. 
Installazione delle librerie client
I seguenti esempi mostrano come installare le librerie client:
Python
Per ulteriori informazioni sulla configurazione dell'ambiente di sviluppo Python, consulta la guida alla configurazione dell'ambiente di sviluppo Python.
# ensure that you are using virtualenv
# as described in the python dev setup guide
pip install --upgrade google-cloud-pubsub
C++
Per maggiori informazioni sull'installazione della libreria C++,
consulta la pagina GitHub README.
C#
Install-Package Google.Cloud.PubSub.V1 -Pre
Vai
go get cloud.google.com/go/pubsub
Java
If you are using Maven, add
the following to your pom.xml file. For more information about
BOMs, see The Google Cloud Platform Libraries BOM.
If you are using Gradle, add the following to your dependencies:
If you are using sbt, add the following to your dependencies:
If you're using Visual Studio Code, IntelliJ, or Eclipse, you can add client libraries to your project using the following IDE plugins:
The plugins provide additional functionality, such as key management for service accounts. Refer to each plugin's documentation for details.
Node.js
npm install @google-cloud/pubsub
PHP
composer require google/cloud-pubsub
Ruby
gem install google-cloud-pubsub
Crea un argomento e una sottoscrizione
Dopo aver creato un argomento, puoi sottoscriverlo o pubblicarvi contenuti.
Utilizza il seguente comando
gcloud pubsub topics create per creare un argomento denominato my-topic. Non modificare
  il nome dell'argomento, perché viene citato nel resto del
  tutorial.
gcloud pubsub topics create my-topic
Utilizza il
comando gcloud pubsub subscriptions
 create per creare un abbonamento. Solo i messaggi pubblicati
nell'argomento dopo la creazione della sottoscrizione sono disponibili per le applicazioni
del sottoscrittore.
gcloud pubsub subscriptions create my-sub --topic my-topic
pubblica dei messaggi
Prima di eseguire gli esempi seguenti, assicurati di rimuovere il commento e inserire i valori obbligatori contrassegnati nel codice. Questo passaggio è necessario per collegare l'esempio al tuo progetto e alle risorse Pub/Sub che hai creato in precedenza.
Utilizza my-topic per l'ID argomento.
Python
C++
C#
Go
Java
Node.js
Node.js
PHP
Ruby
Ricevere messaggi
Configura un sottoscrittore per eseguire il pull dei messaggi appena pubblicati. Ogni sottoscrittore deve inviare un ACK per ciascun messaggio entro una specifica tempistica configurabile. I messaggi non confermati vengono inviati nuovamente. Tieni presente che Pub/Sub a volte consegna un messaggio più di una volta per garantire che tutti i messaggi raggiungano un abbonato almeno una volta.
Prima di eseguire gli esempi seguenti, assicurati di rimuovere il commento e inserire i valori obbligatori contrassegnati nel codice. Questo è necessario per collegare l'esempio al tuo progetto e alle risorse Pub/Sub che hai creato in precedenza.
Utilizza my-sub per l'ID abbonamento.
Per altri esempi che mostrano come estrarre i messaggi, consulta Esempi di codice della libreria client.
Python
C++
C#
Go
Java
Node.js
PHP
Ruby