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();
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");
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");
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();
5. Producteur
Applications qui envoient des messages à des files d'attente de messages ou à des sujets.
MessageProducer producer = session.createProducer(queue);
6. Consommateur
Applications qui reçoivent des messages provenant de files d'attente de messages ou de sujets.
MessageConsumer consumer = session.createConsumer(queue);
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();
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);
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" />
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();
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>
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);
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>
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" />
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());
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>
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();
M
QtT (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.
ActiveMQ fournit une console 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.
Le dépannage d'ActiveMQ implique la vérification des fichiers , 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!<mqttConnectors>
<mqttConnector name="mqtt" persist="true"
uri="mqtt://0.0.0.0:1883" />
</mqttConnectors>