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

Apache ActiveMQ Logo
Basisdaten

Entwickler Apache Software Foundation
Erscheinungsjahr 27. März 2006[1]
Aktuelle Version 6.1.4[2]
(8. November 2024)
Betriebssystem Plattformunabhängig
Programmier­sprache Java
Kategorie Java Message Service Message Oriented Middleware
Lizenz Apache-Lizenz 2.0
activemq.apache.org

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

Bearbeiten

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

Bearbeiten

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

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

Einzelnachweise

Bearbeiten
  1. projects.apache.org. (abgerufen am 8. April 2020).
  2. Release 6.1.4. 8. November 2024 (abgerufen am 15. November 2024).
  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).