2
* JBoss, Home of Professional Open Source
3
* Copyright 2005, JBoss Inc., and individual contributors as indicated
4
* by the @authors tag. See the copyright.txt in the distribution for a
5
* full listing of individual contributors.
7
* This is free software; you can redistribute it and/or modify it
8
* under the terms of the GNU Lesser General Public License as
9
* published by the Free Software Foundation; either version 2.1 of
10
* the License, or (at your option) any later version.
12
* This software is distributed in the hope that it will be useful,
13
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15
* Lesser General Public License for more details.
17
* You should have received a copy of the GNU Lesser General Public
18
* License along with this software; if not, write to the Free
19
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
23
package org.jboss.test.remoting.performance.raw.rmi;
25
import EDU.oswego.cs.dl.util.concurrent.ConcurrentHashMap;
26
import org.jboss.logging.Logger;
27
import org.jboss.test.remoting.performance.synchronous.CallTracker;
28
import org.jboss.test.remoting.performance.synchronous.Payload;
30
import java.rmi.RemoteException;
31
import java.rmi.registry.LocateRegistry;
32
import java.rmi.registry.Registry;
33
import java.rmi.server.UnicastRemoteObject;
37
* @author <a href="mailto:tom.elrod@jboss.com">Tom Elrod</a>
39
public class RMIServer extends UnicastRemoteObject implements RMIServerRemote
41
private static final Logger log = Logger.getLogger(RMIServer.class);
43
private Map callTrackers = new ConcurrentHashMap();
45
private String host = "localhost";
47
public RMIServer(String host) throws RemoteException
53
public Object sendNumberOfCalls(Object obj, Object param) throws RemoteException
55
System.out.println("sent number of calls " + obj + " " + param);
56
String sessionId = (String) obj;
57
Integer totalCountInteger = (Integer) param;
58
int totalCount = totalCountInteger.intValue();
59
System.out.println("received totalCallCount call with total count of " + totalCount + " from " + sessionId);
60
CallTracker tracker = (CallTracker) callTrackers.get(sessionId);
63
tracker.createTotalCount(totalCount);
67
RMIHandler callbackHandler = new RMIHandler(host, sessionId);
68
tracker = new CallTracker(sessionId, callbackHandler);
69
callTrackers.put(sessionId, tracker);
70
tracker.createTotalCount(totalCount);
72
return totalCountInteger;
75
public Object makeCall(Object obj, Object param) throws RemoteException
77
Payload payload = (Payload) param;
78
//System.out.println(payload);
79
int clientInvokeCallCount = payload.getCallNumber();
81
String sessionId = (String) obj;
82
CallTracker tracker = (CallTracker) callTrackers.get(sessionId);
85
tracker.verifyClientInvokeCount(clientInvokeCallCount);
89
log.error("No call tracker exists for session id " + sessionId);
90
throw new RemoteException("No call tracker exists for session id " + sessionId);
92
// just passing return, even though not needed
93
return new Integer(clientInvokeCallCount);
100
// if(System.getSecurityManager() == null)
102
// System.setSecurityManager(new RMISecurityManager());
106
Registry registry = LocateRegistry.createRegistry(port);
108
String name = "//" + host + "/RMIServer";
110
RMIServerRemote engine = new RMIServer(host);
111
// Naming.rebind(name, engine);
112
registry.rebind(name, this);
113
System.out.println("RMIServer bound");
117
System.err.println("RMIServer exception: " + e.getMessage());
122
public static void main(String[] args)
126
String host = "localhost";
127
RMIServer server = new RMIServer(host);
130
catch(RemoteException e)
b'\\ No newline at end of file'