Cajo
aus Wikipedia, der freien Enzyklopädie
Das Projekt cajo ist eine kleine, freie Java-Klassen-Bibliothek. Sie ermöglicht die Kooperation zwischen mehreren virtuellen Maschinen. Das Ziel ist die Vereinfachung des Gebrauchs von RMI.
Erreicht werden soll die Vereinfachung gegenüber RMI wie folgt.
- Im Gegensatz zu RMI werden keine expliziten Schnittstellen definiert.
- Es wird kein RMI-Compiler benötigt, statt Code zu generieren, werden Aufrufe zur Laufzeit via Reflexion durchgeführt.
Das folgende Beispiel zeigt einen einfachen Server, der einfach nur die Zeichenkette „Hallo Client“ an den Client überträgt, wobei der Name des Clients per Parameter übergeben wird. Die Methode „main
“ startet den Server.
import gnu.cajo.invoke.Remote; import gnu.cajo.utils.ItemServer; public class Server { public String hallo(String client) { return "Hallo " + client; } public static void main(String args[]) { try { Remote.config(null, 1198, null, 0); ItemServer.bind(new Server(), "einName"); } catch(Exception e) { e.printStackTrace(); } } }
Der dazu passende Client könnte so aussehen, wobei „serverHost
“ der TCP/IP-Name der Maschine ist, auf der der Server läuft:
import gnu.cajo.invoke.Remote; public class SomeClient { public static void main(String args[]) { try { Object server = Remote.getItem("//serverHost:1198/einName"); String s = (String)Remote.invoke(server, "hallo", "Wiki"); System.out.println("first string = " + s); } catch(Exception e) { e.printStackTrace(); } } }
Dieses Client-Programm würde „Hallo Wiki“ ausgeben.
Wie am Beispiel erkennbar ist, hat der Verzicht auf eine explizite Schnittstelle den Nachteil, dass der Code des Clients etwas schwerer lesbar ist. Statt wie bei Verwendung einer RMI-Schnittstelle zu schreiben „server.hallo("Wiki")
“ wird geschrieben „Remote.invoke(server, "hallo", "Wiki")
“.
Der Verzicht auf die Erzeugung von clientseitigem Stub- und serverseitigem Skeleton-Code ist seit Java 5 auch bei Verwendung von RMI ebenfalls möglich, so dass der zweite Vorteil nicht mehr bedeutend ist.
Am 5. August 2005 vergab die Organisation Internet Assigned Numbers Authority nach mehr als einem Jahr und ausführlicher Kontrolle dem Projekt cajo die offizielle IANA-Port-Nummer: 1198.
[Bearbeiten] Weblinks
- cajo.dev.java.net – cajo Projektseite (englisch)