LinuxQuestions.org
Share your knowledge at the LQ Wiki.
Go Back   LinuxQuestions.org > Forums > Linux Forums > Linux - Networking
User Name
Password
Linux - Networking This forum is for any issue related to networks or networking.
Routing, network cards, OSI, etc. Anything is fair game.

Notices


Reply
  Search this Thread
Old 11-15-2004, 01:08 PM   #1
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Rep: Reputation: 0
Need help routing traffic on 2 network cards


Hi All,

I've got a routing question that could be hard or easy depending on how you look at it.

I have a RH 7.0 machine with 2 network cards. I want to route traffic to my DB with my first card (eth0), and allow my second card (eth1) to handle all other traffic.

I have looked at a few options, but I need a solution that will survive a reboot of the machine and has low overhead.

Thanks for your help on this........
 
Old 11-16-2004, 03:53 PM   #2
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Original Poster
Rep: Reputation: 0
Anyone try this before?
 
Old 11-16-2004, 06:04 PM   #3
bignerd
Member
 
Registered: Nov 2004
Distribution: FC1, Gentoo, Mdk 8.1, RH7-8-9, Knoppix, Zuarus rom 3.13
Posts: 98

Rep: Reputation: 15
More info...
 
Old 11-17-2004, 08:42 AM   #4
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Original Poster
Rep: Reputation: 0
Server Config

eth0 (currently down awaiting setup)
IP 12..28.253.237
BCAST 12.28.253.255
MASK 255.255.255.0
This interface should only communicate with SQL Servers on IP's 12.28.253.25 and 12.28.253.26

eth1
IP 12.28.253.48
BCAST 12.28.253.255
MASK 255.255.255.0
Gateway 12.28.253.58

This interface should communicate all other machines on the network except the 2 SQL Servers.

If there is any more info needed I can look it up.........
 
Old 11-17-2004, 09:33 AM   #5
TreeHugger
Member
 
Registered: Jul 2003
Location: London
Distribution: ubuntu, mint, debian
Posts: 112

Rep: Reputation: 15
are you talking iptables or some other solution?
 
Old 11-17-2004, 09:47 AM   #6
dscott1644
LQ Newbie
 
Registered: Jun 2004
Location: Colorado, USA
Distribution: SuSE 9.1, RH8.0, ...
Posts: 7

Rep: Reputation: 0
Both interfaces are in the same subnet, is this a requirement?

I have not tried running two interfaces to the same subnet for many years, but in general this creates a problem. Normally the routing decission is based on the first (or top most) entry in the table for a given subment. If ETH0's subnet entry happens to be "on-top" of ETH1's subnet then ETH1 may be unreachable, visa-versa if ETH1 is the first entry found. I hedge with "Normally", and "May" as I know there are solutions that allow subnet sharing... ... ... although that is normally to the same set of physicl devices. In the case you outline, you have device set "X" on subnet "A" and another device set "Y" on the same subnet "A", I see this as a difficult or just maybe NOT.

Option1:
If you are forced to use the same subnet, you might be able to use the "longest netmask" rule to your advantage. It sounds like your DB is a single device, and could be concidered a very small subnet by its self. To avoid having to think, assume the last octet of the network address for your DB server is ...6 and your ETH0 IP address it ...5 with a 30 bit mask (255.255.255.252). On ETH1 you showed a 24 bit mask (255.255.255.0) and on a router the longest subnet is positioned higher in the table, thus the more 1-bits in the mask the more perfered the route. I do not know if this would work, as linux might be smart enough to disallow this "trick". If this does work, and you have other routers in the network, they would have to be modified to allow connectivity at which point the request would get the network engineers really upset with you and give you a new subnet.

Option2:
If all your other machines are restricted to a single subnet because you have no other router in the network. Because all devices are on the same physical network on the same subnet, then every device already has direct access to the DB server. If this is the case just add a static route in /etc/hosts pointing to the DB server. If I could find my glasses I could look it up for you, but I think if you use the command:
route add -net <db server IP address> netmask 255.255.255.255 eth0
an entry will be added to your hosts table saying to use eth0 only to access this device.

Is this sort of the thing you looking for?

Oops.. I just reread and see you are talking about 2 DB servers. If that is the save then the subnet mask in option 1 would be different and in option 2 you would have to insert 2 static routes.

Last edited by dscott1644; 11-17-2004 at 09:49 AM.
 
Old 11-17-2004, 09:49 AM   #7
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Original Poster
Rep: Reputation: 0
I really don't know what the best solution is. The problem is the one active interface is overloaded with too much traffic. Half of the traffic goes to a DB and the other half goes to various other machines. By adding a second interface and routing it to the DB I expect the load will be reduced and performance improved. Unfortunately I haven't found a good example of this being done and the details on how to do it. Any help would be appreciated.
 
Old 11-17-2004, 11:15 AM   #8
dscott1644
LQ Newbie
 
Registered: Jun 2004
Location: Colorado, USA
Distribution: SuSE 9.1, RH8.0, ...
Posts: 7

Rep: Reputation: 0
The easiest (and I feel best) solution would be to create a new LAN segment for your DB servers and insert a router between the existing LAN segment and the new LAN segment (you would then have 2 subnet). Your Linux server would be connected to both LAN segments and the other devices would only be on the original LAN segment. The Linux machine would know the best path to each LAN segment automatically so all you would have to do is put the IP address on the interface and do a ifconfig up. How the router would need to be configured and changing each hosts gateway address would depend on what the rest of the network looks like.


Internet
|
Router
/ \ <---- gateway addresses
/ \
/ -------------
/ | existing LAN
-------- |
| | |
DB Linux
Servers

I don't know if the Internet is in the picture or not. An alternate approach would be:

Internet
|
Router1
| <---- gateway address for existing LAN devices including Linux
|
--------------------------------
| | existing LAN
| |
Linux Router2
| | <----- gateway address for DB servers
| |
---------------------
DB
Servers

** a routing protocol would be needed between Router1 and Router2 which could include a dynamic routing protocol or manually using static routes.

*** EDITED comment here *** I was afraid the spaces would be changed to nulls making my wonderful stick figure drawings somewhat difficult to read. Can you figure out how to insert the spaces to make this make sense?

Last edited by dscott1644; 11-17-2004 at 11:17 AM.
 
Old 11-17-2004, 11:48 AM   #9
emetib
Member
 
Registered: Feb 2003
Posts: 484

Rep: Reputation: 33
if your db's are being accessed from the outside and not just 127, then you would be able to insert a rule into your firewall rules. i seen the version of redhat, are you running the old kernel(2.2) still, or have you upgraded(2.4-2.6)?

if you've upgraded then i would take a look at the iptables documentation-
http://www.netfilter.org/documentation/index.html

if not then you will have to look at the ipchains which i don't have a page for.

basically you will have your zones defined, eth0, eth1, loc, net, and so on. now you will have a fw that ties theses together and in the spot for eth0 you open up the routing for db's, for eth1 you shut it down.

i would set up your dhcp to give the db's a static address on that subnet that you're setting up. you can do that with your mac addresses from the db machines so it shouldn't be all that hard.
 
Old 11-17-2004, 12:54 PM   #10
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Original Poster
Rep: Reputation: 0
Thanks all for your recommendations. I'll try them out and report on my success.
 
Old 11-17-2004, 03:08 PM   #11
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Original Poster
Rep: Reputation: 0
Hi All,

Thanks for your input everyone. I have found that the Option 2 (route add -net <db server IP address> netmask 255.255.255.255 eth0) will work best in this situation because all machines are on the same network, attached to the same switch, and other machines communicate to the same DB. I have tested this option out and it appears to work well. But there is one problem. When I reboot the machine this route goes away.

Do you know if there is a way to make this change permanent or make a change somewhere else that will be permanent. I saw a file named /etc/sysconfig/static-routes, but don't know if this is the right place or the format to put the entry in.

Thanks for your help.........
 
Old 11-17-2004, 04:37 PM   #12
dscott1644
LQ Newbie
 
Registered: Jun 2004
Location: Colorado, USA
Distribution: SuSE 9.1, RH8.0, ...
Posts: 7

Rep: Reputation: 0
You might want to place the comend into /etc/rc.d/rc.local. If things are still like they use to be, you should just add:
/sbin/route add -net <db server IP address> netmask 255.255.255.255 eth0
to rc.local.
 
Old 11-19-2004, 09:08 AM   #13
dan6767
LQ Newbie
 
Registered: Nov 2004
Posts: 7

Original Poster
Rep: Reputation: 0
Thanks dscott and everyone. This solution is working, and it survives a reboot!!


I am seeing packet loss when pinging the machine I am routing to (41%, 50%, 61%, etc). This may be a separate issue which I'll need to troubleshoot............
 
Old 11-19-2004, 09:40 AM   #14
dscott1644
LQ Newbie
 
Registered: Jun 2004
Location: Colorado, USA
Distribution: SuSE 9.1, RH8.0, ...
Posts: 7

Rep: Reputation: 0
I agree, that should be a separate issue.

Just a suggestion: Buy 2 additional ethernet cards to be inserted into each DB server, plus a small switch (or build a VLAN on an existing switch). Connect your Linux server and your 2 DB servers (new ethernet interfaces) to this newly created LAN segment using a completely different IP subnet. This is not really a very expensive solution and it will provide you with the very high performance configureation I think you are looking for.

Are you currently using a switch or a hub for your existing ethernet connectivity? If you are currently using a hub, you might want to get a 4 or 5 port switch connecting your Linux server Eth0, DB1 and DB1 plus a cross-over cable between the switch and the existing hub (that'd fill up 4 ports). Although the LinkSys and NetGear switchs are NOT enterprise quality, mine have been working flawlessly for a couple years now.
 
  


Reply


Thread Tools Search this Thread
Search this Thread:

Advanced Search

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is Off
HTML code is Off



Similar Threads
Thread Thread Starter Forum Replies Last Post
routing traffic from 2 machines on same network masand Linux - Networking 3 08-27-2005 10:34 PM
Routing traffic fuelinjection Linux - Networking 3 04-01-2005 05:51 PM
2 network cards, 2 network connections - routing problem tvojvodi Linux - Networking 4 02-24-2004 03:26 PM
Routing Problem with two network cards a.tangemann Linux - Networking 0 02-23-2004 04:07 AM
ip routing table. getting network cards working hamish Linux - Networking 2 11-30-2003 05:58 PM

LinuxQuestions.org > Forums > Linux Forums > Linux - Networking

All times are GMT -5. The time now is 09:30 AM.

Main Menu
Advertisement
My LQ
Write for LQ
LinuxQuestions.org is looking for people interested in writing Editorials, Articles, Reviews, and more. If you'd like to contribute content, let us know.
Main Menu
Syndicate
RSS1  Latest Threads
RSS1  LQ News
Twitter: @linuxquestions
Open Source Consulting | Domain Registration