服务端
IRemoteMath.java
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface IRemoteMath extends Remote {
public double add (double a, double b) throws RemoteException;
public double subtract(double a, double b) throws RemoteException;
}
RemoteMath.java
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
public class RemoteMath extends UnicastRemoteObject implements IRemoteMath{
public RemoteMath() throws RemoteException{
}
@Override
public double add(double a, double b) throws RemoteException {
return a + b;
}
@Override
public double subtract(double a, double b) throws RemoteException {
return a - b;
}
}
Server.java
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
public class Server {
static String ip = "172.16.17.153";
static String name = "Compute";
static int port = 1099;
public static void main(String[] args) throws RemoteException {
exec2();
}
static void exec1() {// Naming实现方式(这种方式目前有问题)
try {
LocateRegistry.createRegistry(1099);
IRemoteMath remote = new RemoteMath();
Naming.rebind("rmi:/172.16.17.217:1099/Compute", remote);
System.out.println("Math server ready");
} catch (Exception e) {
e.printStackTrace();
}
}
static void exec2() {// LocateRegistry实现方式
try {
System.setProperty("java.rmi.server.hostname", ip); // 多个IP一定要加这一行
LocateRegistry.createRegistry(port);
IRemoteMath remote = new RemoteMath();
Registry registry = LocateRegistry.getRegistry(ip, port);
registry.bind(name, remote);
System.out.println("Math server ready");
} catch (Exception e) {
e.printStackTrace();
}
}
}
客户端
IRemoteMath.java
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface IRemoteMath extends Remote {
public double add (double a, double b) throws RemoteException;
public double subtract(double a, double b) throws RemoteException;
}
Client.java
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.RMISocketFactory;
public class Client {
static String ip = "172.16.17.217";
static String name = "Compute";
static int port = 1099;
public static void main(String[] args) {
exec2();
}
// 这种方式目前有问题
static void exec1() {
try {
System.setProperty("java.rmi.server.hostname", ip);
IRemoteMath remoteMath = (IRemoteMath) Naming.lookup("rmi:/" + ip + ":" + port + "/" + name);
double addResult = remoteMath.add(5.0, 3.0);
System.out.println("5.0 + 3.0 = " + addResult);
double subResult = remoteMath.subtract(5.0, 3.0);
System.out.println("5.0 - 3.0 = " + subResult);
} catch (Exception e) {
e.printStackTrace();
}
}
static void exec2() {
try {
Registry registry = LocateRegistry.getRegistry(ip, port);
IRemoteMath remoteMath = (IRemoteMath) registry.lookup(name);
double addResult = remoteMath.add(5.0, 3.0);
System.out.println("5.0 + 3.0 = " + addResult);
double subResult = remoteMath.subtract(5.0, 3.0);
System.out.println("5.0 - 3.0 = " + subResult);
} catch (Exception e) {
e.printStackTrace();
}
}
}