Zum Inhalt springen

Apache MINA

aus Wikipedia, der freien Enzyklopädie
Dies ist die aktuelle Version dieser Seite, zuletzt bearbeitet am 10. November 2025 um 16:31 Uhr durch ~2025-32540-86 (Diskussion) (typo korrigiert).
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)
Apache MINA

[[Datei:Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value)|150px]]
Basisdaten

Maintainer Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value)
Entwickler Apache Software Foundation
Erscheinungsjahr Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value)
Aktuelle Version Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value)
(Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value))
Aktuelle Vorabversion Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value)
(Lua-Fehler in Modul:Wikidata, Zeile 1686: attempt to index field 'wikibase' (a nil value))
Betriebssystem plattformunabhängig
Programmier­sprache Java
Kategorie Netzwerkkommunikationsframework
Lizenz Apache-Lizenz 2.0
mina.apache.org

Apache MINA ist ein freies Java Framework für Netzwerkkommunikation. Es stellt eine ereignisbasierte Programmierschnittstelle für asynchrone Kommunikation über Transportprotokolle wie TCP/IP and UDP/IP und Java NIO zur Verfügung.

MINA ist ein Akronym für Multipurpose Infrastructure for Network Applications.<ref>FAQ – What does MINA mean? Abgerufen am 5. Juni 2013.</ref>

Funktionsweise

Apache MINA ist primär eine technologieunabhängige Programmierschnittstelle für verschiedene Netzwerkprotokolle. Diese können über ByteBuffers, StreamIoHandler oder benutzerdefinierte Message Objekte und Codecs angesprochen werden. Die mitgelieferten Protokolle sind:

Darüber hinaus können eigene Protokolle implementiert werden. Die Netzwerkkommunikation kann single-threaded oder durch konfigurierbare Thread-Pools abgewickelt werden.<ref name="features">Trustin Lee: Apache MINA Features. Apache Software Foundation, 24. Juli 2007, abgerufen am 8. März 2016 (englisch).</ref>

Apache MINA bietet Unterstützung für die Absicherung von Überlast, Bandbreitenkontrolle, Unit-Testen über Mock-Objekte, Management und Überwachung via Java Management Extensions sowie Integrationen mit den Dependency Injection Frameworks PicoContainer und Spring.<ref name="features" />

Apache Camel kann als Routing und Konvertierungs-Engine für Apache MINA verwendet werden.

Geschichte

Apache MINA basiert auf dem im Juni 2004 von Trustin Lee erstmals veröffentlichten Netzwerk Framework "Netty2". Es war das erste entsprechende Java Framework, welches auf einer ereignisbasierten Architektur aufbaute, hatte allerdings Schwierigkeiten mit Text-Protokollen und architektonische Fehler, die seinen Einsatz in massiv parallelen Systemen verhinderte.

Alex Karasulu vom Apache Directory Team arbeitete zur gleichen Zeit selbst an einem Netzwerk-Framework und wurde auf Netty2 aufmerksam. Er konnte Trustin Lee zur Zusammenarbeit an einem neuen Netzwerk Framework für das Apache Directory Projekt bewegen. Im September 2004 wurde basierend auf einer Mischung aus den Architekturen der beiden Frameworks die Grundlage für Apache MINA geschaffen.

Seit damals ist Apache MINA das primäre Netzwerk Framework des Apache Directory Projektes für diverse Protokolle des Apache Directory Servers – u. a. LDAP, Kerberos, DNS und NTP.<ref>Trustin Lee: Genesis of MINA. Apache Software Foundation, 30. Januar 2007, abgerufen am 8. März 2016 (englisch).</ref>

Alternativen

Neben der direkten Verwendung der Java-Programmierschnittstellen für NIO, Socket und TCP/IP- und UDP/IP-Kommunikation gibt es noch folgende alternative Frameworks zur Netzwerkkommunikation in Java:

  • Grizzly
  • Netty 4
  • QuickServer
  • xSocket

Einzelnachweise

<references />