Thank Assirati for such detailed help!
I will try your solution tomorrow.

On Thu, Mar 7, 2013 at 6:06 PM, João Luis Meloni Assirati
<assir...@nonada.if.usp.br> wrote:
> Em 07-03-2013 05:11, Long Wind escreveu:
>
>> I am writing java programs
>> I want to bind to a socket: new DatagramSocket(95);
>>
>> when running it I find only root can bind that way
>>
>> Can I give  user permission to bind that way?
>
>
> Usually, ports below 1024 are reserved for root use (because they are used
> by standard services like http, smtp, ssh etc). The linux kernel provides
> "posix capability" (this is the technical name) that can be given to a
> binary executable through the command setcap:
>
> setcap cap_net_bind_service=+ep <program>
>
> which must be run as root, evidently. This command sets up some permissions
> stored in the filesystem that allow <program> to bind to ports below 1024.
> Think of it as a limited form of suid bit, but giving only bind()
> privileges.
>
> However, you are not runing an executable binary, but bytecode in a virtual
> machine. I suggest that you try to set those capabilities to the java
> virtual machine executable. In my system, it would be
>
> setcap cap_net_bind_service=+ep
> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
>
> I don't know if the java interpreter will "drop privileges" like bash does
> if it is suid. It would be nice to know, though. This method has two
> disadvantages
>
> 1. The bind capability is not restricted to one port.
> 2. Any program runing in the virtual interpreter
> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java will have the bind
> priviledges.
>
> Another way to solve this problem which does not suffer from the drawbacks
> above would be to make your program to bind to an unprivileged port, say,
> 9595, and, redirect to this port all the income in port 95. This can be done
> with iptables, just run as root the commands:
>
> iptables -t nat -A PREROUTING -p tcp -m tcp --dport 95 -j REDIRECT
> --to-ports 9595
> iptables -t nat -A OUTPUT -p tcp -m tcp --dport 95 -j REDIRECT --to-ports
> 9595
>
> These commands must be rerun in each reboot, so you may want to put the in
> /etc/init.d/rc.local.
>
> João Luis.
>


--
To UNSUBSCRIBE, email to debian-user-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org
Archive: 
http://lists.debian.org/cab-gxzatpkwk8wprt6hyuhb+5-joeyewehvqd6i-3rnymuy...@mail.gmail.com

Reply via email to