So I see that HTTP tunneling over RMI has been removed in Java 9.
We sell commercial Java software, which runs in Tomcat. Our customers install this on their Mac, Windows, and Linux servers. This software is then accessed by the public, with a Java Swing client interface. It uses RMI for communication with the server software.
Most of our customers have firewalls preventing access to the server on any port other than 80/443. This is not a problem for Java 8 and earlier, which can use RMI over dynamic ports or switch to HTTP when a firewall blocks access.
However, removing the HTTP proxy feature in Java 9 means that most of our customers will no longer be able to use our software, as currently architected. It is impractical and insecure for our customers to configure their firewalls and servers for SSH access from the public, especially for customers running Windows servers.
Does this mean that we need to rewrite our application architecture to use some network protocol other than RMI? Or is there a way to keep RMI in Java 9? Ditching RMI entirely will require a complete rewrite of our user-facing application code, and is not a cost effective option.
Seems like JDK-8023862 already deprecated HTTP proxying from RMI as also mentioned in the release notes of Java8.
As suggested in #JDK8180642 which also inquires of an alternative to removal of HTTP proxy implementation from RMI. One of the alternatives could be to use ssh to tunnel through the proxy.
Use ssh to establish a local port that is tunneled through the proxy to the remote machine. The connection will be more functional than the HTTP proxy implementation.
In the chained links you can find an article over how can one make outgoing Java RMI calls through a local firewall? which suggests other implementations such as SOCKS and socket factories as well.
So I see that HTTP tunneling over RMI has been removed in Java 9.
Not surprising. It was a poor solution, one-way, with a 10x performance penalty.
Does this mean that RMI is dead?
No. It is part of Java as of 1.1 and the history of Java since then, twenty years ago, is a remarkable record of backwards compatibility. The last breakage in ABI compatibility was when they changed the AWT event model between 1.0 and 1.1. It would be astonishing if RMI was ever removed from Java, and there is nothing in the removal of RMI/HTTP tunneling that justifies you in jumping to this conclusion.
We currently use RMI extensively for building client-server user interfaces. It's common for our clients to have firewalls blocking dynamic ports, so we revert to HTTP tunneling.
You will certainly need another solution for tunneling. SSH comes to mind.
How should we deal with this in Java 9?
See above.
Ditching RMI entirely will require a complete rewrite of our user-facing application code.
There is nothing to suggest such a necessity.
Regarding RMI port usage:
super(port,...)
if you extend UnicastRemoteObject
, or UnicastRemoteObject.exportObject(object, port, ...)
if you don't.So for example if you export a Registry and then more remote objects from the same JVM, they will by default share port 1099, or you can explicity force it.
If you are using an RMIServerSocketFactory
you need to provide it with an appropriate equals()
method to preserve these semantics.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With