From: Andrew McGregor <andrew@indranet.co.nz>
To: Ben Greear <greearb@candelatech.com>, root@chaos.analogic.com
Cc: Tomas Szepe <szepe@pinerecords.com>, lkml <linux-kernel@vger.kernel.org>
Subject: Re: [OT] ipv4: how to choose src ip?
Date: Fri, 06 Dec 2002 22:06:07 +1300 [thread overview]
Message-ID: <44180000.1039165567@localhost.localdomain> (raw)
In-Reply-To: <3DF026A4.5010801@candelatech.com>
--On Thursday, December 05, 2002 20:25:08 -0800 Ben Greear
<greearb@candelatech.com> wrote:
> Richard B. Johnson wrote:
>> On Thu, 5 Dec 2002, Tomas Szepe wrote:
>
>>> I'm not interested in rewriting the source address with netfilter based
>>> on destination and/or service; What I'm looking for is rather a way to
>>> initiate two connections to the same destination host using the two
>>> different source IP addresses.
>>>
>>
>>
>> The simple answer is that if you need a specific IP address
>> associated with a "multi-honed" host, that has only one interface,
>> then something is broken. And you get to keep the pieces.
Not always so. I'm writing an app (userspace HIP, see www.hip4inter.net)
that needs this too. And it would be nice if there were a simple way to do
it. VoIP apps need this sometimes too.
>> The IP addresses assigned to a multi-honed host are the addresses
>> to which it will respond during ARP. The ARP (Address Resolution
>> Protocol) you remember, is the protocol used to get the "hardware"
>> or IEEE station address of the interface.
>>
>> Any IP protocol will properly work with any IP address embedded in
>> the packet from the interface that responded to the ARP.
Um. No, this isn't right. The interface in question could be PPP, or
something wierd like IP over FireWire, neither of which do ARP. ARP is
specifically for IPv4 over ethernet or something which emulates ethernet.
IPv6 doesn't use ARP even on ethernet, yet source address selection is even
more important in that case. Nearly every IPv6 application will need to do
it, or trust the kernel to do it right. Random is not an option.
And applications *do not* necessarily work with any old address in the
header; otherwise NAT would never be a problem.
>> However, the IP address inside the data-gram will usually be
>> the IP address of the interface that first sent that packet.
>> The IP address used is the address of the interface that met
>> the necessary criteria for getting the data-gram onto the wire.
>> In other words, the net-mask and the network address are the
>> determining factors. If you have two or more IP addresses that
>> are capable of putting the data-gram on the wire, the first one,
>> i.e., the address used to initialize the interface first, will
>> be the one that is used in out-going packets.
This just describes the usual behaviour of unix-like systems. But the most
recently configured address would be just as correct a default.
> You may be able to influence this with policy-based routing and
> the arp-filter code.
You can select what you want this way, yes. But there should be a way to
select source addresses from among those already configured without having
to have the ability to change the routing table or firewall rules! Hence:
> You certainly can bind to a specific IP and/or port when initiating
> a connection. You can use the local IP to do source-based routing.
> I have not done exactly the thing described here, but I have done
> similar things, certainly binding to ports & ips on both server
> and initiator side of an IP connection.
>
>
>> There is no RightWay(tm) because any attempt to choose a specific
>> IP to on the wire from a machine that has only one interface, but
>> is multi-honed, is broken at the start. However, you can chose where
>
> I think you presume too much about what other people might consider
> broken or not. :)
What's more, the specs actually say otherwise. That's something you MUST
be able to do (see the sockets API RFC). And in IPv6 sometimes only the
application can know what to do.
Andrew
next prev parent reply other threads:[~2002-12-06 10:42 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2002-12-05 19:00 [OT] ipv4: how to choose src ip? Tomas Szepe
2002-12-05 20:37 ` Richard B. Johnson
2002-12-05 20:56 ` Brad Hards
2002-12-05 21:38 ` Tomas Szepe
2002-12-06 4:25 ` Ben Greear
2002-12-06 9:06 ` Andrew McGregor [this message]
2002-12-06 15:13 ` Richard B. Johnson
2002-12-05 20:58 ` Willy Tarreau
2002-12-05 21:39 ` Tomas Szepe
2002-12-06 15:27 ` Mark Frazer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=44180000.1039165567@localhost.localdomain \
--to=andrew@indranet.co.nz \
--cc=greearb@candelatech.com \
--cc=linux-kernel@vger.kernel.org \
--cc=root@chaos.analogic.com \
--cc=szepe@pinerecords.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.