Apache ActiveMQ

Apache ActiveMQ

Apache ActiveMQ Logo
Basisdaten

EntwicklerApache Software Foundation
Erscheinungsjahr27. März 2006[1]
Aktuelle Version5.18.3[2]
(24. Oktober 2023)
BetriebssystemPlattformunabhängig
ProgrammierspracheJava
KategorieJava Message Service Message Oriented Middleware
LizenzApache-Lizenz 2.0
activemq.apache.org

Apache ActiveMQ ist ein freier Message Broker, der vollständig das Java Message Service 1.1 (JMS) implementiert. Apache ActiveMQ verändert die Verbindungen eines Netzwerks zwischen bestehenden Anwendungen, indem die synchrone Kommunikation zwischen zu integrierenden Applikationen in eine asynchrone Kommunikation umgewandelt wird.

Apache ActiveMQ wird von Enterprise Service Bus Implementierungen wie Apache ServiceMix und Mule verwendet. Apache ActiveMQ selbst wiederum inkludiert Apache Camel 2.0 und KahaDb Persistent Storage.

Funktionalitäten

Abgesehen von JMS unterstützt er die Protokolle AMQP 1.0, MQTT, OpenWire, REST, STOMP und WebSocket. Als Programmiersprache können Java, das .NET-Framework[3], sowie C[4], Ruby, Perl, Python oder PHP eingesetzt werden.

Er beinhaltet weitere Features wie z. B. Clustering und die Verwaltung von Nachrichten und Client-Implementierungen.

ActiveMQ kann direkt auf einer herkömmlichen Java Virtual Machine (JVM) ausgeführt werden, der Einsatz eines Applikationsservers ist nicht nötig.[5]

Definition

ActiveMQ wird entweder als JMS Provider (Anbieter) oder als Broker (Makler) bezeichnet und übernimmt damit die Rolle eines Servers. Alle anderen Anwendungen im JMS Netzwerk werden dagegen als JMS-Clients bezeichnet.

Ein Broker kennt zwei Arten von Destinationen (Reiseziel, Zielort) – Queue und Topic. Sobald der Broker die erste Nachricht für dieses Reiseziel empfangen hat, wird in beiden Fällen die Destination samt ihrer Art automatisch festgestellt.

Queues kennen zwei Arten von Clients – Erzeuger (Producer) und Verbraucher (Consumer). Hat ein Verbraucher eine Nachricht von einem Erzeuger empfangen, wird diese Nachricht aus der Queue gelöscht und steht den anderen Verbrauchern nicht mehr zur Verfügung. Eine Nachricht kann also nur von einem einzelnen Verbraucher empfangen (konsumiert) werden.

Topics kennen ebenfalls zwei Arten von Clients – Publisher und Subscriber. In diesem Fall ist es jedoch möglich, dass mehrere Subscriber die gleiche Nachricht empfangen.

Literatur

  • Bruce Snyder, Dejan Bosanac, Rob Davies: ActiveMQ in Action. Hrsg.: Manning Publications. 1. Auflage. 2010, ISBN 978-1-933988-94-8.

Einzelnachweise

  1. projects.apache.org. (abgerufen am 8. April 2020).
  2. Release activemq-5.18.3. 24. Oktober 2023.
  3. NMS Clients. In: Apache ActiveMQ. The Apache Software Foundation, abgerufen am 5. November 2023 (englisch).
  4. ActiveMQ - C Integration. The Apache Software Foundation, abgerufen am 5. November 2023 (englisch).
  5. ActiveMQ. In: Apache ActiveMQ. The Apache Software Foundation, abgerufen am 17. Oktober 2023 (englisch).

Auf dieser Seite verwendete Medien

Apache ActiveMQ Logo.svg
Autor/Urheber: The Apache Software Foundation, Lizenz: Apache License 2.0
Apache ActiveMQ Logo