Usare l'API Java Message Service 2.0 con il Bus di servizio di Azure Premium
Questo articolo illustra come usare l'API Java Message Service (JMS) 2.0 comune per interagire con il Bus di servizio di Azure tramite il protocollo Advanced Message Queueing Protocol (AMQP) 1.0.
Nota
Il supporto per l'API JMS 2.0 è disponibile solo nel livello Premium e quando si usa la libreria azure-servicebus-jms . Se si usano librerie JMS diverse da azure-servicebus-jms (ad esempio, la versione più recente di qpid-jms-client) in uno spazio dei nomi Premium, si osserva il comportamento JMS 1.1. La libreria azure-servicebus-jms non crea un blocco fornitore di qualsiasi tipo perché accetta ancora una dipendenza da qpid-jms-client. Tutte le API che funzionano su qpid-jms-client funzionano anche nella libreria azure-servicebus-jms.
Azure-servicebus-jms è anche una libreria open source. La libreria azure-servicebus-jms è stata creata principalmente in modo che il servizio bus di servizio possa distinguere tra i clienti che necessitano del comportamento JMS 1.1 (compatibilità con le versioni precedenti) rispetto al comportamento di JMS 2.0 quando si usa uno spazio dei nomi Premium. La libreria azure-servicebus-jms fornisce anche alcune impostazioni predefinite necessarie, ad esempio i valori dei criteri di prelettura, i criteri di riconnessione, l'ID di Microsoft Entra, il supporto dell'identità gestita, il supporto per l'eliminazione automatica inattiva per le entità predefinite.
Il percorso seguente del pacchetto azure-servicebus-jms è la versione più recente della libreria basata sulla specifica Jakarta Messaging (API Jakarta.*): Maven Central: com.azure:azure-servicebus-jms. Il percorso seguente di azure-servicebus-jms è la versione più recente della libreria prima della specifica Messaging di Jakarta (javax.* APIs): Maven Central: com.microsoft.azure:azure-servicebus-jms.
Prerequisiti
Introduzione al bus di servizio
Questa guida presuppone che si disponga già di uno spazio dei nomi del Bus di servizio. In caso contrario, creare uno spazio dei nomi e una coda usando il portale di Azure. Per altre informazioni su come creare spazi dei nomi e code del Bus di servizio, vedere Introduzione alle code del Bus di servizio tramite il portale di Azure.
Configurare un ambiente di sviluppo in Java
Per sviluppare applicazioni Java, è necessario configurare l'ambiente di sviluppo appropriato:
- JDK (Java Development Kit) o JRE (Java Runtime Environment) è installato.
- JDK o JRE viene aggiunto al percorso di compilazione e alle variabili di sistema appropriate.
- Un IDE Java viene installato per usare JDK o JRE. Ad esempio, Eclipse o IntelliJ.
Per altre informazioni su come preparare l'ambiente per sviluppatori per Java in Azure, usare questa guida.
Quali funzionalità JMS sono supportate?
La tabella seguente elenca le funzionalità di Java Message Service (JMS) attualmente supportate dal bus di servizio di Azure. Mostra anche le funzionalità non supportate.
Funzionalità | API | Status |
---|---|---|
Code |
|
Supportata |
Argomenti |
|
Supportata |
Code temporanee |
|
Supportata |
Argomenti temporanei |
|
Supportata |
Producer di messaggi/ JMSProducer |
|
Supportata |
Browser di accodamento |
|
Supportata |
Consumer di messaggi/ JMSConsumer |
noLocal non è attualmente supportato |
Supportata |
Sottoscrizioni durevoli condivise |
|
Supportata |
Sottoscrizioni durevoli non condivise |
noLocal non è attualmente supportato e deve essere impostato su false |
Supportata |
Sottoscrizioni non durevoli condivise |
|
Supportata |
Sottoscrizioni non durevoli non condivise |
noLocal non è attualmente supportato e deve essere impostato su false |
Supportata |
Selettori di messaggi | dipende dal consumer creato | Supportata |
Ritardo recapito (messaggi pianificati) |
|
Supportata |
Messaggio creato |
|
Supportata |
Transazioni tra entità |
|
Supportata |
Transazioni distribuite | Non supportato |
Download della libreria client Java Message Service (JMS)
Per usare tutte le funzionalità disponibili nel livello Premium, aggiungere la libreria seguente al percorso di compilazione del progetto: azure-servicebus-jms. Questo pacchetto fornisce alcune impostazioni predefinite necessarie, ad esempio i valori dei criteri di pre-recupero, i criteri di riconnessione, Microsoft Entra ID e il supporto dell'identità gestita.
Nota
Per aggiungere azure-servicebus-jms al percorso di compilazione, usare lo strumento di gestione delle dipendenze preferito per il progetto, ad esempio Maven o Gradle.
Compilazione di applicazioni Java
Dopo l'importazione delle dipendenze, le applicazioni Java possono essere scritte in modo indipendente dal provider JMS.
Connessione al bus di servizio di Azure con JMS
Per connettersi al Bus di servizio di Azure usando i client JMS, è necessaria la stringa di connessione disponibile in "Criteri di accesso condiviso" nel portale di Azure in Stringa di connessione primaria.
Creare un'istanza di
ServiceBusJmsConnectionFactorySettings
ServiceBusJmsConnectionFactorySettings connFactorySettings = new ServiceBusJmsConnectionFactorySettings(); connFactorySettings.setConnectionIdleTimeoutMS(20000);
Creare un'istanza di
ServiceBusJmsConnectionFactory
con l'oggetto appropriatoServiceBusConnectionString
.String ServiceBusConnectionString = "<SERVICE_BUS_CONNECTION_STRING_WITH_MANAGE_PERMISSIONS>"; ConnectionFactory factory = new ServiceBusJmsConnectionFactory(ServiceBusConnectionString, connFactorySettings);
Usare
ConnectionFactory
per creare un oggettoConnection
e quindi unSession
Connection connection = factory.createConnection(); Session session = connection.createSession();
o
JMSContext
(per i client JMS 2.0)JMSContext jmsContext = factory.createContext();
Importante
Anche se con lo stesso nome, una sessione JMS e una sessione del Bus di servizio sono completamente indipendenti l'una dall'altra.
In JMS 1.1, la sessione è un blocco predefinito essenziale dell'API che consente la creazione di
MessageProducer
,MessageConsumer
eMessage
. Per altre informazioni, vedere il modello di programmazione dell'API JMSNel Bus di servizio le sessioni sono costrutto sul lato servizio e sul lato client per abilitare l'elaborazione FIFO nelle code e nelle sottoscrizioni.
Scrivere l'applicazione JMS
Dopo aver creato un'istanza di Session
o JMSContext
, l'applicazione può usare le API JMS familiari per eseguire operazioni di gestione e dati. Fare riferimento all'elenco delle funzionalità JMS supportate per vedere quali API sono supportate. Ecco alcuni frammenti di codice di esempio per iniziare a usare JMS:
Invio di messaggi a una coda e a un argomento
// Create the queue and topic
Queue queue = jmsContext.createQueue("basicQueue");
Topic topic = jmsContext.createTopic("basicTopic");
// Create the message
Message msg = jmsContext.createMessage();
// Create the JMS message producer
JMSProducer producer = jmsContext.createProducer();
// send the message to the queue
producer.send(queue, msg);
// send the message to the topic
producer.send(topic, msg);
Ricezione di messaggi da una coda
// Create the queue
Queue queue = jmsContext.createQueue("basicQueue");
// Create the message consumer
JMSConsumer consumer = jmsContext.createConsumer(queue);
// Receive the message
Message msg = (Message) consumer.receive();
Ricezione di messaggi da una sottoscrizione durevole condivisa in un argomento
// Create the topic
Topic topic = jmsContext.createTopic("basicTopic");
// Create a shared durable subscriber on the topic
JMSConsumer sharedDurableConsumer = jmsContext.createSharedDurableConsumer(topic, "sharedDurableConsumer");
// Receive the message
Message msg = (Message) sharedDurableConsumer.receive();
Riepilogo
Questa guida ha illustrato in che modo le applicazioni client Java che usano Java Message Service (JMS) su AMQP 1.0 possono interagire con il Bus di servizio di Azure.
È anche possibile utilizzare AMQP 1.0 per il bus di servizio da altri linguaggi, tra cui .NET, C, Python e PHP. I componenti creati con questi linguaggi possono scambiare messaggi in modo affidabile e con la massima fedeltà grazie al supporto per AMQP 1.0 nel bus di servizio.