Maison > Java > javaDidacticiel > le corps du texte

20 concepts incontournables pour Java ActiveMQ

WBOY
Libérer: 2024-02-21 08:40:07
avant
1053 Les gens l'ont consulté

Java ActiveMQ 的 20 个必知概念

Java ActiveMQ est un middleware de messagerie open source populaire largement utilisé dans le développement d'applications d'entreprise. Lorsque vous utilisez ActiveMQ, il est important de comprendre certains concepts clés. Dans cet article, l'éditeur PHP Apple présente 20 concepts incontournables de Java ActiveMQ pour vous aider à mieux comprendre et utiliser ce puissant middleware de messages. En comprenant ces concepts en profondeur, vous serez en mesure d'exploiter ActiveMQ plus efficacement pour créer un système de messagerie stable et fiable.

ActiveMQ Composant principal responsable du traitement de tous les flux de messages. Il fournit une plate-forme sur laquelle les applications peuvent se connecter, envoyer et recevoir des messages.

BrokerService broker = new BrokerService();
broker.addConnector("tcp://0.0.0.0:61616");
broker.start();
Copier après la connexion

2. File d'attente des messages

Le concept logique de stockage des messages dans ActiveMQ Containers. Message Queue peut recevoir des messages de plusieurs producteurs et les transmettre à plusieurs consommateurs.

Queue queue = session.createQueue("my-queue");
Copier après la connexion

3. Thème

Modèle de publication/abonnement, les producteurs de messages publient des messages sur un sujet et les consommateurs intéressés peuvent s'abonner au sujet et recevoir tous les messages publiés.

Topic topic = session.createTopic("my-topic");
Copier après la connexion

4.Conversation

Session de communication entre l'application et le courtier ActiveMQ. Les sessions permettent aux applications d'envoyer et de recevoir des messages, ainsi que de gérer des transactions.

Session session = broker.createSession();
Copier après la connexion

5. Producteur

Applications qui envoient des messages à des files d'attente de messages ou à des sujets.

MessageProducer producer = session.createProducer(queue);
Copier après la connexion

6. Consommateur

Applications qui reçoivent des messages provenant de files d'attente de messages ou de sujets.

MessageConsumer consumer = session.createConsumer(queue);
Copier après la connexion

7. Affaires

Un ensemble d'opérations, soit toutes exécutées, soit toutes annulées. ActiveMQ prend en charge les transactions pour garantir une messagerie fiable et cohérente.

session.begin();
producer.send(message);
session.commit();
Copier après la connexion

8. Durabilité

La persistance des messages détermine si les messages sont conservés lorsque le courtier est redémarré ou échoue. Les messages persistants seront conservés sur le disque, tandis que les messages non persistants seront perdus.

Message message = session.createTextMessage("Hello world");
message.setPersistent(true);
producer.send(message);
Copier après la connexion

9. Pont

Permet aux messages d'un courtier ActiveMQ d'être transmis à un autre courtier. Les ponts peuvent être utilisés pour connecter plusieurs instances ActiveMQ.

<bridge destination="forward.my-topic"
source="activemq:topic:my-topic"
brokerName="broker-b" />
Copier après la connexion

10. Transfert de machine virtuelle

Permet de connecter deux instances d'ActiveMQ au sein de la même JVM. Ceci est utile pour tester ou créer des systèmes distribués dans un environnement autonome.

BrokerService brokerA = new BrokerService();
BrokerService brokerB = new BrokerService();
brokerA.setVmConnectorURI(brokerB.getVmConnectorURI());
brokerA.setBrokerName("broker-a");
brokerB.setBrokerName("broker-b");
brokerA.start();
brokerB.start();
Copier après la connexion

11.Plugin

ActiveMQ fournit un mécanisme pour étendre ses fonctionnalités. Les Plugins peuvent ajouter de nouvelles fonctionnalités telles que le stockage des messages, la sécurité ou la surveillance.

<plugins>
<journalPlugin>
<journalDirectory>/tmp/journal</journalDirectory>
</journalPlugin>
</plugins>
Copier après la connexion

12.Conversion des messages

ActiveMQ permet de convertir les messages entre différents formats de message. Les convertisseurs peuvent être utilisés pour convertir XML en JSON ou pour convertir des messages texte en messages binaires.

MessageConverter converter = session.getMessageConverter();
Message message = converter.toMessage("Hello world", session);
producer.send(message);
Copier après la connexion

13. Basculement

Assurez la disponibilité en cas de défaillance du courtier de messages en utilisant un courtier de basculement ou un clustering. Lorsque l'agent principal tombe en panne, l'agent de sauvegarde prend le relais.

<broker cluster="my-cluster">
<networkConnectors>
<networkConnector name="tcp" uri="tcp://0.0.0.0:61616" />
</networkConnectors>
</broker>
Copier après la connexion

14. Équilibrage de charge

Amélioration de l'évolutivité et des performances en répartissant la charge des messages entre plusieurs courtiers. ActiveMQ prend en charge les stratégies d'équilibrage de charge basées sur la taille des messages ou le round robin.

<broker loadBalancingPolicy="round-robin" />
Copier après la connexion

15. Surveillance

La surveillance du courtier ActiveMQ est essentielle pour garantir son bon fonctionnement et ses performances. ActiveMQ fournit un tableau de bord JMX et REST

api

pour surveiller l'état du courtier et le flux de messages.

import org.apache.activemq.broker.jmx.BrokerViewMBean;

BrokerViewMBean brokerView = (BrokerViewMBean) MBeanServerFactory.createMBeanServer().getObjectInstance(new ObjectName("org.apache.activemq:type=Broker,brokerName=localhost"));
System.out.println("Message count: " + brokerView.getQueueSize());
Copier après la connexion

16. Sécurité

ActiveMQ fournit divers mécanismes de sécurité, notamment SSL, SASL et des listes de contrôle d'accès.

<securitySettings>
<sslProtocols>TLSv1,TLSv1.1,TLSv1.2</sslProtocols>
<requireCredentialsForAllConnections>true</requireCredentialsForAllConnections>
<audit>true</audit>
</securitySettings>
Copier après la connexion

17. Accord

ActiveMQ prend en charge plusieurs protocoles de messagerie, notamment AMQP, JMS et STOMP.

BrokerService broker = new BrokerService();
broker.setBrokerName("my-broker");
broker.addConnector("stomp://0.0.0.0:61613");
broker.start();
Copier après la connexion

18.MQTT

M

Qt

T (Message Queuing Telemetry Transport) est un protocole léger développé spécifiquement pour les appareils Internet des objets (IoT) . ActiveMQ prend en charge MQTT, ce qui le rend idéal pour connecter des appareils IoT et des systèmes d'entreprise.

<mqttConnectors>
<mqttConnector name="mqtt" persist="true"
 uri="mqtt://0.0.0.0:1883" />
</mqttConnectors>
Copier après la connexion
19.Console Web

ActiveMQ fournit une console

WEB

qui permet aux administrateurs de surveiller l'état du courtier, de gérer les files d'attente et les sujets, ainsi que de gérer les plugins.

20. Dépannage

Le dépannage d'ActiveMQ implique la vérification des fichiers

logs

, de l'interface graphique d'état et des tableaux de bord JMX. En analysant soigneusement les messages d'erreur et les journaux, les problèmes peuvent être rapidement diagnostiqués et résolus.

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!

source:lsjlt.com
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
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!