Mit RMI Server: Methodenaufruf Client zuordnen

Status
Nicht offen für weitere Antworten.
T

tuxedo

Gast
Servus,

ich stehe gerade vor dem Problem dass ich mit meinem RMI Server nicht weiß welcher Client die jeweilige Servermethode aufruft...

Folgendes Szenario:

Der Client holt sich das RMI Serverobjekt und ruft damit eine Login-Methode am Server auf. Als Argument übergibt der Client der Methode ein Callback-Objekt gemäß folgendem Interface:

Code:
public interface ClientCallback extends Remote {....}

Das funktioniert prima. Der Server kann dann mit diesem Objekt Methoden beim Client aufrufen. Soweit so gut.
Wenn sich der Client nun ausloggen möchte ruft er eine Logout-Methode im Serverobjekt auf.

Aber woher weiß jetzt der Server welcher Client die Methode aufgerufen hat? Kann mir irgendwie nicht vorstellen, dass der Client immer seine ID als Argument übergeben muss damit der Server weiß woher der Aufruf kommt.

Was mich auch gerade etwas verwirrt: Hab ich mit RMI multiple Serverobjekt-Instanzen (jeder Client erhält eine eigene Instanz) oder greifen alle verbundenen Clients auf ein und dasselbe Objekt zu?

*verwirrt bin*

Kann mir da jemand helfen?


Gruß
Alex

[update]

okay, scheinbar gibt es nur eine einzige Serverobjekt-Instanz die alle Clients erhalten (hab die String-Repräsentation des Rmi-Serverobjekts bei mehreren verbundenen Clients verglichen).
 

Niki

Top Contributor
Wenn du das Remote Objekt in der Registry registrierst bekommt jeder Client das SELBE Objekt. Damit jeder Client sein eigenes Objekt hat brauchst du ein weiteres Remote Objekt. Dieses wird jedoch nicht in der Registry hinterlegt, sondern vom Remote Objekt, welches in der Registry liegt, zurück gegeben. Das heißt das Objekt in der Registry ist nur ein Session-Objekt erzeuger. Java ist so klug und erkennt dass die Methode vom Remote-Objekt der Registry von einer anderen VM aufgerufen worden ist und liefert dir daher den Stub des eigentlichen Session-Objekts zurück.
Damit der Ablauf ein wenig verständlicher ist:

RemoteObjekt1 hat Methode: Session getNewSession();
Session ist RemoteObjekt2
Server registriert RemoteObjekt1 in Registry
Client holt RemoteObjekt1 vom Server und ruft getNewSession auf, der Server erkennt, dass er den Stub zurück geben muss und liefert dem Client ein neues Session Objekt (also den Stub).
Der Client hat jetzt sein eigenes Session Objekt mit dem er am Server arbeiten kann. Falls du Code Beispiele brauchst sag bescheid, dann werd ich schnell mal eins runter klopfen!
 
T

tuxedo

Gast
Ja, Codebeispiele wären nett....

Ein einfaches Gerüst würde ja reichen.

thx,

Alex
 

Niki

Top Contributor
Bitte sehr:
Code:
package server;

import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

public class Server {
	public static void main(String[] args) throws Exception {
		SessionFactory factory = new SessionFactoryImpl();
		Registry reg = null;
		try {
			reg = LocateRegistry.getRegistry(1099);
			reg.rebind(SessionFactory.SERVICE_NAME, factory);
		} catch (Exception ex) {
			reg = LocateRegistry.createRegistry(1099);
			reg.bind(SessionFactory.SERVICE_NAME, factory);
		}
		while(true){
			System.gc();
			Thread.sleep(10000);
		}
	}
}


package server;

import java.rmi.Remote;

public interface Session extends Remote {
	
}


package server;

import java.rmi.Remote;
import java.rmi.RemoteException;

public interface SessionFactory extends Remote{
	public Session getNewSession() throws RemoteException;
	
	public static final String SERVICE_NAME = "SessionFactory";
}


package server;

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

public class SessionFactoryImpl extends UnicastRemoteObject implements SessionFactory {
	public SessionFactoryImpl() throws RemoteException{
		
	}
	
	public Session getNewSession() throws RemoteException {
		return new SessionImpl();
	}
}


package server;

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

public class SessionImpl extends UnicastRemoteObject implements Session {
	public SessionImpl() throws RemoteException{

	}	
}


package client;

import server.Session;

public class Client {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception{
		Session session = ServerSessionFactory.getSession();
		System.out.println(session);

	}

}


package client;

import java.rmi.Naming;

import server.Session;
import server.SessionFactory;

public class ServerSessionFactory {
	
	
	private static SessionFactory factory = null;
	
	public static String host = "localhost";
	
	public static int port = 1099;
	
	private static synchronized SessionFactory getSessionFactory() throws Exception{
		if(factory == null)
			factory = (SessionFactory)Naming.lookup("//" + host + ":" + port + "/" + SessionFactory.SERVICE_NAME);
		return factory;
	}
	
	public static Session getSession() throws Exception{
		return getSessionFactory().getNewSession();		
	}
}
 
T

tuxedo

Gast
Vielen Dank. Ich werd's mir jetzt mal zu Gemüte führen...

thx,
Alex
 
T

tuxedo

Gast
So, angesehen und verstanden.. Ist ja eigentlich recht easy. Einfach im äußeren RMI-Server-Objekt ein weiteres Remote-Objekt zurückgegen lassen. Jo, vielen dank nochmal für das Codebeispiel.



- Alex
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Websockets oder server sent events? Netzwerkprogrammierung 2
W Windows 2019-Server Dienste starten unter Nutzer Netzwerkprogrammierung 1
F http Post auf einen Grafana Server Netzwerkprogrammierung 3
W Socket Server -> lesen von / schreiben zu php-script Netzwerkprogrammierung 6
E Server mit GUI Netzwerkprogrammierung 4
E FTP FTPS Server gibt Fehlernachricht "522 SSL/TLS required on the data channel" zurück Netzwerkprogrammierung 1
I Performanteste Kommunikationsmethode zwischen Client u. Server Netzwerkprogrammierung 4
L Socket Automatische Zuweisung von Server und Client Rolle Netzwerkprogrammierung 12
Eigenen Rechner als Server? Netzwerkprogrammierung 16
FrankenDerStein HTTP Https Server Bibliothek für Linux und Android gesucht. Netzwerkprogrammierung 7
ExceptionOfExpectation Server/Client-Kommunikation Netzwerkprogrammierung 34
M Server-Client-System für Browsergame Netzwerkprogrammierung 5
J Datei Download vom Server Netzwerkprogrammierung 8
izoards Mehrere TCP Verbindungen auf einen Server [alles Local] Netzwerkprogrammierung 2
Yonnig Threads mit Client/Server und GUI (laufend bis button-click) Netzwerkprogrammierung 9
J Client-Server und SOAP Netzwerkprogrammierung 23
K Threads/Server/telnet Fehler Netzwerkprogrammierung 2
J Multithreaded-Server Netzwerkprogrammierung 21
JaXnPriVate Java HTTPS Server (Secure Sockets) Netzwerkprogrammierung 15
L30nS RMI RMI-Server kann Dialog nicht volkommen anzeigen Netzwerkprogrammierung 2
L30nS RMI Aufruf einer Client-Methode von einem RMI-Server Netzwerkprogrammierung 3
L Server-Socket liest Input-Stream nicht Netzwerkprogrammierung 5
T String von Client zu Server kommt nicht an Netzwerkprogrammierung 92
D WebSocket Server mit HTML Client und Java Server Netzwerkprogrammierung 5
S Von Java auf passwortgeschützten Server zugreifen + Umgang mit Ports Netzwerkprogrammierung 28
S Probleme bei Java-Installation auf Server (Linux/Shell/Terminal) Netzwerkprogrammierung 6
S Java: Anbindung an einen realen Server? (+ Portfreigabe) Netzwerkprogrammierung 8
D Server - Client Informationsaustausch, Möglichkeiten Netzwerkprogrammierung 3
H Socket Kann ein Socket server 2 dimensionale Arrays empfangen und versenden? Netzwerkprogrammierung 3
H Socket Chat entwickeln mit Java Server Client Netzwerkprogrammierung 4
X Kann ich einen Client/Server verbindung hinkriegen die mir alle paar Sekunden die aktuellen Daten per Realtime zuschickt ? Netzwerkprogrammierung 9
Z Kann nicht Daten vom Server lesen Socket Netzwerkprogrammierung 10
S HTTP Post?!? - Java Server Netzwerkprogrammierung 7
F Verbindung zu einem LDAP Server über Java Netzwerkprogrammierung 4
D Slf4j - Logging - Client-Server Architektur Netzwerkprogrammierung 3
F NodeJs-Server auf Firebase hosten ? Netzwerkprogrammierung 3
J client server mit nur einem PC Netzwerkprogrammierung 33
M Socket Nachricht von TCP-Client an Server schicken Netzwerkprogrammierung 12
M Socket Verbindung Matlab(Server) Java(Client) Netzwerkprogrammierung 1
H HTTP Glassfish (v5) Application Server - Bibliothek zur Verfügung stellen Netzwerkprogrammierung 4
B HttpClient - Server (Jetty) - getInputStream - EOF Netzwerkprogrammierung 3
P TCP-Server Netzwerkprogrammierung 1
R Socket FATAL EXCEPTION MAIN bei Socket based client/server app Netzwerkprogrammierung 2
F Server für Java Applikationen Netzwerkprogrammierung 16
H Einfacher Server funktioniert nicht Netzwerkprogrammierung 1
G Server-Client IO Problem Netzwerkprogrammierung 6
T Mikrofonaudio über Java Server an Webbrowser streamen Netzwerkprogrammierung 13
I Socket Das erste Server-Client Programm Netzwerkprogrammierung 16
T HTTPS-Requests an Server: POST-Parameter kommen nicht an Netzwerkprogrammierung 5
L Socket Wie kann ich checken ob ein User eine Nachricht per Outputstream an den Server gesendet hat? Netzwerkprogrammierung 1
T Jetty Server LOGGING Netzwerkprogrammierung 1
L Strings an Server senden und in MYSQL speichern? Netzwerkprogrammierung 3
Aruetiise Socket Java Programm auf Server Netzwerkprogrammierung 3
T server empfängt nur 1 Buchstaben vom String Netzwerkprogrammierung 1
S Spiel mit Server programmieren Netzwerkprogrammierung 2
N Post u Head Request an Server Netzwerkprogrammierung 4
J Socket Ein Chat Server Tutorial Netzwerkprogrammierung 8
M Socket Server antwortet dem Client nicht Netzwerkprogrammierung 6
J Socket Tutorial zu Multiplayer Server schreiben? Netzwerkprogrammierung 5
S Java Chat Server Netzwerkprogrammierung 8
E Kurze Textnachrichten über einen Server von meinem Handy auf den Computer laden. Netzwerkprogrammierung 9
I Client/Server Kommunikation bei einem Spiel Netzwerkprogrammierung 4
E Objekte versenden, Client-Server Netzwerkprogrammierung 25
C Mini Client-Server-Anwendung funktioniert nicht Netzwerkprogrammierung 8
D Socket Message an einen Server senden? Netzwerkprogrammierung 8
J FTP FTP Zugriff über Proxy Server Netzwerkprogrammierung 1
KaffeeFan Programmierung mit Cloud-Server Netzwerkprogrammierung 0
L Socket Problem mit Server Netzwerkprogrammierung 1
cezary Socket Paralleler Server ? Netzwerkprogrammierung 1
I Socket Leicht zu DDosender Server Netzwerkprogrammierung 4
agent47 HTTPs Server Netzwerkprogrammierung 5
J Chat Server starten über GUI problem Netzwerkprogrammierung 4
J Prüfen, ob remote UDT Server erreichbar ist Netzwerkprogrammierung 0
P Server als Client nutzen Netzwerkprogrammierung 8
S Server Kommunikation Netzwerkprogrammierung 1
V einfaches hin und her von Text über Server Netzwerkprogrammierung 2
D Socket Run Args Client/Server Socket Netzwerkprogrammierung 1
Cromewell Socket Multithreaded Server und Client Netzwerkprogrammierung 1
Y Client/Server/DB communication Netzwerkprogrammierung 3
JavaWolf165 Socket mit .writeUtf etwas vom Client zum Server schicken Netzwerkprogrammierung 13
P RMI Client Server Programm über Internet Netzwerkprogrammierung 2
brainless Client Server Kommunikation verschlüsseln Netzwerkprogrammierung 13
gamebreiti Socket Server / Client Anwendung Manipulation von Objekten durch Server Netzwerkprogrammierung 9
T Socket Server/Client Kommunikation Netzwerkprogrammierung 8
S Webservice - Server Netzwerkprogrammierung 0
M Java Eingabe auf FTP Server übergeben Netzwerkprogrammierung 4
F Server Client Anwendung mit UDP Netzwerkprogrammierung 2
A RMI Wo treten Exceptions bei RMI Aufrufen auf? Auf Client oder auf Server? Netzwerkprogrammierung 3
M Socket Java Server: NullPointerException Netzwerkprogrammierung 4
A ByteBuffer - Client/Server Netzwerkprogrammierung 9
J Java Server empfängt php inhalt nicht Netzwerkprogrammierung 1
K C# Server - Android Client Netzwerkprogrammierung 0
J Framework mehrere Clients/ Server-Broadcast/oracle XE/ XML Netzwerkprogrammierung 1
D Mit Server Daten austauschen Netzwerkprogrammierung 4
V Server / mehrere Clients / MySQL / Konzept Netzwerkprogrammierung 2
P HTTP Bild von einem Server per http kopieren Netzwerkprogrammierung 1
F Verbindung zwischen Server und handy Netzwerkprogrammierung 1
P MIME-TYPE Erklaerung, Kommunikation zwischen Client und Server Netzwerkprogrammierung 3
J Sichere Kommunikation bei Server Client Netzwerkprogrammierung 3
R RMI Server RMI Netzwerkprogrammierung 1

Ähnliche Java Themen


Oben