cannot access host from outside with Private IP and Public IP in java

X

xeon Mailinglist

n a Linux OS, when a program get the IP address with "getHostAddress()". it gets the first IP address available.
In a host with 2 interfaces, eth0 and eth1, the method will get the eth0 IP address by default.

I have a host that is behind a NAT, and I cannot change the host IP addresses, or the order of the interfaces.
In the host, eth0 is a private address, and in eth1 is an address that NAT knows.
If I want to reach the host from outside, I connect to an IP that NAT will translate into the address of eth1.

I need to use the private IP address to run a java service (Hadoop MapReduce) correctly, and not the eth1 address.
I tried to set Hadoop with the eth1 address but the service won't run giving me a not allowed exception.

1 - Now I want to contact the Hadoop service that is running behind the NAT from the internet, and the service is registered with the private address. Is it possible to reach that node?

2 - If I could bind eth1 to the java service, I could reach the host from outside?

3 - If I could update the NAT table with the private address of the host, I could already reach the host from outside?
 
J

Joerg Meier

n a Linux OS, when a program get the IP address with "getHostAddress()". it gets the first IP address available.
In a host with 2 interfaces, eth0 and eth1, the method will get the eth0 IP address by default.

While I cannot help you with that at all with practical advice, it occured
to me that there is really no way that this issue is not already solved for
producs such as Tomcat or Glassfish, both of which are open source. Maybe
you can find an answer there.

Liebe Gruesse,
Joerg
 
A

Arne Vajhøj

n a Linux OS, when a program get the IP address with "getHostAddress()". it gets the first IP address available.
In a host with 2 interfaces, eth0 and eth1, the method will get the eth0 IP address by default.

I have a host that is behind a NAT, and I cannot change the host IP addresses, or the order of the interfaces.
In the host, eth0 is a private address, and in eth1 is an address that NAT knows.
If I want to reach the host from outside, I connect to an IP that NAT will translate into the address of eth1.

I need to use the private IP address to run a java service (Hadoop MapReduce) correctly, and not the eth1 address.
I tried to set Hadoop with the eth1 address but the service won't run giving me a not allowed exception.

1 - Now I want to contact the Hadoop service that is running behind the NAT from the internet, and the service is registered with the private address. Is it possible to reach that node?

2 - If I could bind eth1 to the java service, I could reach the host from outside?

3 - If I could update the NAT table with the private address of the host, I could already reach the host from outside?

I think that the right solution is to have the service listen on the
eth1 IP address.

So I recommend that you investigate the "but the service won't run
giving me a not allowed exception".

Arne
 
A

Andreas Leitgeb

Arne Vajhøj said:
and the service is registered with the private address. Is it possible to reach that node?
I think that the right solution is to have the service listen on the
eth1 IP address.
So I recommend that you investigate the "but the service won't run
giving me a not allowed exception".

I agree with Arne and want to add, that if for some reason your Java app
needs to know the name by which external clients will be able to connect
to it, then there is "almost" no way other than have that external name
configured somewhere in the app.

"almost"? Well, I don't know exactly about "upnp", but there might be a
way involving upnp if your NAT'ing router allows it.

The "not allowed" exception likely results from trying to bind to an
address that the linux box doesn't itself "know" as its own. You really
need to to have your application bind to the eth1's address in your scenario.
Beyond that, either read up on upnp or just allow the external address
(the one that would be given to clients) to be manually configured.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
473,982
Messages
2,570,185
Members
46,736
Latest member
AdolphBig6

Latest Threads

Top