Apache ActiveMQ
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 | |
---|---|
Basisdaten | |
Entwickler | Apache Software Foundation |
Erscheinungsjahr | 27. März 2006[1] |
Aktuelle Version | 5.16.1[2] (14. Januar 2021) |
Betriebssystem | Plattformunabhängig |
Programmiersprache | 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
Abgesehen von JMS unterstützt er Protokolle wie AMQP 1.0, STOMP und OpenWire und neben Java auch die Programmiersprachen der .NET-Familie[3], sowie C[4], Ruby, Perl, Python oder PHP.
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.
Weblinks
- The Apache Software Foundation – Website des Herstellers
Einzelnachweise
- projects.apache.org. (abgerufen am 8. April 2020).
- git-wip-us.apache.org.
- Apache NMS project, the .NET Messaging API
- Apache ActiveMQ - C Integration
- Apache ActiveMQ --Index - Activemq.Apache.org