我在一个框架中工作,在这个框架中,远程对象像这样导出自身:UnicastRemoteObject.exportObject(this, port, csf, ssf);
这只是一个假设,不能改变它。我现在正在尝试包含RMIIO lib来进行远程迭代。RMIIO使用UnicastRemoteObject.exportObject(Remote, int)导出远程对象,根据Javadoc的说法,它使用RMISocketFactory。默认情况下,RMIIO将端口设置为0(任何端口)。
现在我绝对需要RMIIO来重用所有其他对象使用的现有RMI端口(它是防火墙中唯一打开的端口),并尊重我对套接字工厂的设置,因为SSL和压缩等。除了更改第三方代码之外,最好的方法是什么?我使用的是Java 8。
我曾希望有一些系统属性可以让我从外部控制套接字工厂,但似乎没有。
因此,现在我认为我需要以编程方式调用RMISocketFactory.setSocketFactory(RMISocketFactory)。对吗?对我来说,这听起来有点多此一举。当我这样做时,我不需要担心为库指定端口,这是正确的吗?因为当我的套接字工厂适当地实现equals()和hashCode()时,RMI会自动尝试并重用它。
塞巴斯蒂安
发布于 2018-06-15 17:25:05
我发现RMIIO库的一个特性确实解决了我的问题:您可以提供自己的类来导出远程对象。该类可以通过系统属性指定。因此,底层Java远程流实现与调用它的RPC框架解耦。很好的设计!
https://stackoverflow.com/questions/50864523
复制相似问题