java - 从一台服务器串行调用 Java RMI 到另一台服务器

标签 java rmi

是否可以从服务器到其他服务器串行调用 Java RMI?

RMI 客户端 1 >--(1)--->RMI 服务器 1 >---(2)-----> RMI 服务器 2

意味着 RMI 客户端 1 将调用 RMI 服务器 1 上的方法,并且 RMI 服务器 1 将调用其他 RMI 服务器 2 代理客户端上的方法..对于同一执行程序中的 RMI 服务器 2

请帮忙..

代码在这里: 异常:java.lang.ClassCastException:$Proxy0 无法转换为 interfc2

rmiserver1.java

import java.rmi.*;
import java.rmi.server.*;

import java.io.*;
import java.util.*;


class rmiserver1 extends UnicastRemoteObject implements interfc1
{
public rmiserver1() throws RemoteException
{
    System.out.println("RMIServer 1 Constructor ");
}


public String remote1() 
{
    System.out.println("here Calling RMIServer2 method remote2 ");
                try
                {
                    interfc2 obj2=(interfc2) Naming.lookup("rmi://localhost/rmiserver2");
                    String r2=obj2.remote2();
                    System.out.println("Result from rmiserver2 :"+r2);
                }
                catch(Exception e){e.printStackTrace();}

    return "RMIServer1 remote 1 method return here....";

}


public static void main(String[] args) 
{
    System.out.println("RMIServer 1 Main method ");

    try
            {
                rmiserver1 p1=new rmiserver1();
                    Naming.rebind("rmiserver1",p1);

            System.out.println("RMIServer 1 rebinded ");

            }
            catch (Exception e)
            {
                e.printStackTrace();
            }

}
 }

interfc1.java

 import java.rmi.*;
 import java.io.*;
 import java.util.*;

public interface interfc1 extends Remote
{
public String remote1() throws RemoteException;
}

interfc2.java

import java.rmi.*;
import java.io.*;
import java.util.*;

public interface interfc2 extends Remote
{
public String remote2() throws RemoteException;
}

rmiserver2.java

import java.rmi.*;
import java.rmi.server.*;

import java.io.*;
import java.util.*;


class rmiserver2 extends UnicastRemoteObject implements interfc2
{
public rmiserver2() throws RemoteException
{
    System.out.println("RMIServer 2 Constructor ");
}


public String remote2() 
{
    return "RMIServer2 remote 2 method return here....";
}


public static void main(String[] args) 
{
    System.out.println("RMIServer 2 Main method ");

    try
            {
                rmiserver1 p1=new rmiserver1();
                    Naming.rebind("rmiserver2",p1);

            System.out.println("RMIServer 2 rebinded ");

            }
            catch (Exception e)
            {
                e.printStackTrace();
            }

}
}

rmiclient1.java

import java.rmi.*;
import java.rmi.server.*;

import java.io.*;
import java.util.*;



class rmiclient1  
{
public static void main(String[] args) 
{
    System.out.println("RMIClient 1 Main method");

    try
    {
        interfc1 obj1=(interfc1) Naming.lookup("rmi://localhost/rmiserver1");
        String r1=obj1.remote1();
        System.out.println("Result from rmiserver1 :"+r1);
    }
    catch(Exception e){e.printStackTrace();}
}
}

rmiserver1 提示异常:

 java.lang.ClassCastException: $Proxy0 cannot be cast to interfc2
    at rmiserver1.remote1(rmiserver1.java:23)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke   (NativeMethodAccessorImpl.
java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
sorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:305)
    at sun.rmi.transport.Transport$1.run(Transport.java:159)
    at java.security.AccessController.doPrivileged(Native Method)
    at sun.rmi.transport.Transport.serviceCall(Transport.java:155)
    at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:5
35)
    at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTranspor
t.java:790)
    at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport
.java:649)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExec
utor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor
.java:908)
    at java.lang.Thread.run(Thread.java:619)

强调文本

最佳答案

我认为您的 RMI 服务器 1 必须为操作 2 的 RMI 客户端实现接口(interface)。因此它将充当进程 1 的服务器和进程 2 的客户端。

关于java - 从一台服务器串行调用 Java RMI 到另一台服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8328121/

相关文章:

java - 使用 Wildfly 16.0.0.Final 和 ejb 客户端的 TLS/SSL 失败并显示 org.xnio.http.UpgradeFailedException : Invalid response code 200

java - 我想列出微调Firebase中所有唯一的子代和键以及值。

java - Context.createSubcontext 抛出异常 javax.naming.OperationNotSupportedException

java - 从不同的项目调用不同的包

java - 在Java中测试MongoDB : concurrency problems

java - 如何从 RestTemplate postForLocation 获取 STRING 响应?

java - 服务器断开连接时如何在传输过程中将客户端切换到第二个服务器

Java RMI NotBoundException?

java 。通信两个点对点应用程序

java.rmi.ServerException : RemoteException occurred in server thread (ClassNotFoundException) 异常