Maison > Java > javaDidacticiel > Utilisation de JNDI pour la connexion JMS dans le développement d'API Java

Utilisation de JNDI pour la connexion JMS dans le développement d'API Java

WBOY
Libérer: 2023-06-18 09:21:52
original
1286 Les gens l'ont consulté

Alors que le développement d'applications d'entreprise modernes repose de plus en plus sur des systèmes distribués, l'utilisation de files d'attente de messages est devenue de plus en plus importante. Java Message Service (JMS) est une API orientée message qui peut être utilisée pour créer facilement des systèmes de messagerie. Java Naming and Directory Interface (JNDI) est l'API standard de Java pour accéder aux services de noms et d'annuaire. Dans le développement d'API Java, l'utilisation de JNDI pour la connexion JMS peut nous faciliter la gestion et l'utilisation des files d'attente de messages.

  1. JNDI Introduction

JNDI est une API Java principalement utilisée pour accéder aux services de noms et d'annuaire au moment de l'exécution. Il fournit une méthode commune pour accéder à divers services de noms et d'annuaire tels que le protocole LDAP (Lightweight Directory Access Protocol), le système de noms de domaine (DNS) et l'architecture Common Object Request Broker (CORBA). JNDI cache les détails des services de noms et d'annuaire en coulisses, permettant aux développeurs de se concentrer uniquement sur la manière d'obtenir et d'utiliser les objets fournis par le service.

  1. Introduction à JMS

JMS est une API orientée message permettant de transmettre des messages entre applications. En utilisant JMS, nous pouvons envoyer des messages à une file d'attente ou à un sujet et les recevoir à une heure spécifiée. JMS offre la possibilité de messagerie asynchrone, ce qui en fait un moyen idéal de communiquer entre des systèmes distribués.

  1. Utilisez JNDI pour vous connecter à JMS

Dans le développement d'API Java, l'utilisation de JNDI pour la connexion JMS est très pratique. Voici les étapes de base pour se connecter à JMS :

3.1 Créer un contexte JNDI

Tout d'abord, nous devons créer un contexte JNDI. Dans JMS, un contexte est l'objet chargé de gérer les connexions et les destinations. Vous pouvez utiliser le code suivant pour créer un contexte initial JNDI :

Hashtable<String, String> env = new Hashtable<>();
env.put(Context.INITIAL_CONTEXT_FACTORY,"org.apache.activemq.jndi.ActiveMQInitialContextFactory");
env.put(Context.PROVIDER_URL, "tcp://localhost:61616");
Context context = new InitialContext(env);
Copier après la connexion

3.2 Obtenez les objets ConnectionFactory et Destination

Ensuite, nous devons obtenir les objets ConnectionFactory et Destination. ConnectionFactory est l'objet d'usine utilisé pour créer des connexions, tandis que Destination représente la destination où les messages sont envoyés et reçus. Si vous utilisez ActiveMQ, vous pouvez utiliser le code suivant pour obtenir ces objets :

ConnectionFactory factory = (ConnectionFactory) context.lookup("ConnectionFactory");
Destination destination = (Destination) context.lookup("dynamicQueues/TEST.QUEUE");
Copier après la connexion

3.3 Créer une connexion et une session

Après avoir obtenu ConnectionFactory et Destination, nous pouvons créer le Objets Connexion et Session . Lors de la création d'une connexion à l'aide d'une ConnectionFactory, vous pouvez également spécifier un nom d'utilisateur et un mot de passe. Le code suivant montre comment créer une connexion :

Connection connection = factory.createConnection("username", "password");
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Copier après la connexion

3.4 Créer un producteur et un consommateur

Maintenant, nous pouvons créer un producteur (pour envoyer des messages) et un consommateur (pour recevoir messages). Le code suivant montre comment créer ces objets :

MessageProducer producer = session.createProducer(destination);
MessageConsumer consumer = session.createConsumer(destination);
Copier après la connexion

3.5 Envoi et réception de messages

Enfin, nous pouvons utiliser Producer pour envoyer des messages et Consumer pour recevoir des messages. Le code suivant montre comment effectuer ces opérations :

TextMessage message = session.createTextMessage("Hello World!");
producer.send(message);

Message receivedMessage = consumer.receive();
if (receivedMessage instanceof TextMessage) {
    TextMessage textMessage = (TextMessage) receivedMessage;
    String text = textMessage.getText();
    System.out.println(text);
}
Copier après la connexion
  1. Summary

En général, dans le développement d'API Java, utilisez JNDI pour vous connecter à JMS Peut nous aider à gérer et à utiliser les files d’attente de messages plus facilement. En utilisant JNDI, nous pouvons facilement obtenir ConnectionFactory et Destination et créer une connexion, une session, un producteur et un consommateur. Vous pouvez également envoyer et recevoir des messages facilement. Par conséquent, l'utilisation de JNDI pour se connecter à JMS constitue un bon choix pour les applications d'entreprise qui doivent utiliser fréquemment JMS.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal