我正在通过 SSH 隧道传输 cajo rmi 流量。
为此,我有一个运行 SSH 守护程序(apache Mina)的服务器和一个运行 SSH 客户端(Trilead SSH)的客户端。
可以建立这些机器之间的 shh 连接,并且通过应用本地和远程端口转发,我可以隧道 rmi 流量,但这仅适用于出站(到服务器)方向。
设置:
活动 SSH 连接(端口 22)
客户端:将本地端口 4000 转发到远程主机端口 1198(此流量实际上通过隧道) 服务器:将服务器端口 4000 转发到客户端端口 1198(这部分隧道未被使用焦糖)
服务器使用以下方法导出对象:
Remote.config(null, 1198, null, 0);
ItemServer.bind(new SomeObject(), "someobject");
客户端使用以下方法进行对象查找:
ObjectType someObject = (ObjectType)TransparentItemProxy.getItem(
"//localhost:4000/someobject",
new Class[] { ObjectType.class });
logger.info(someObject.getName());
在客户端使用 trilead ssh 库调用端口转发:
conn.createLocalPortForwarder(4000, "Server-IP", 1198);
conn.requestRemotePortForwarding("localhost" 4000, "Client-IP", 1198);
使用 WireShark 分析两台机器之间的 ip 流量时,我看到查找正在通过隧道重定向,但响应不是。响应通常发送到客户端的 1198 端口。
如何强制服务器将远程调用的响应发送到本地端口,以便通过隧道返回客户端?
更新:这里的问题是 RMI 对象的端口与注册表端口不同,因此也需要转发。
简而言之,客户端 10.0.0.1 查找 //10.0.0.1:4000 并转发到服务器上的 RMI 端口(通过隧道)。随后服务器响应 10.0.0.1:1198 ,我希望服务器将其流量发送到其本地端口 4000,以便使用隧道。
我试图摆弄 cajo Remote.config(ServerAddress, ServerPort, ClientAddress, ClientPort) 设置,但是当我将此方法的 clientaddress 设置为 10.0.0.1 或 127.0.0.1 时,我无法得到回复,我根本看不到任何响应流量...