ICMP Redirects not being sent from CentOS Router

Written by James McDonald

August 7, 2008

Update: This ended up being an iptables problem… The firewall rules I had were “stateful” so the icmp redirect was being killed by IPTables because it didn’t identify the redirect as part of an already started connection. After changing it from stateful to non-stateful (I did this in the fwbuilder gui so I can’t show you the exact IPTables code) the redirects started flowing and working as they should.

Suppose you have the following network setup.

The client computers default gateway is When the client contacts it’s default gateway while attempting to connect to a host on the subnet the default gateway ( sends an ICMP Redirect to tell the client that the correct router to use is

By running tcpdump "icmp" on the default gateway router a redirect looks like this:

tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth0, link-type EN10MB (Ethernet), capture size 96 bytes
09:56:37.410824 IP > ICMP redirect to host, length 48

The client (in this case a Windows XP Pro workstation) will then update it’s routing table to reflect the better route.

route print

Active Routes:
Network Destination        Netmask          Gateway       Interface  Metric
       30       1       30       30       30       1       1       30       1
Default Gateway:

The router sending the redirect is governed by some kernel settings. The default settings for CentOS 5.x are shown here:

net.ipv4.conf.all.send_redirects = 1
net.ipv4.conf.eth0.send_redirects = 1
net.ipv4.conf.default.send_redirects = 1

net.ipv4.route.redirect_silence = 20480
net.ipv4.route.redirect_number = 9
net.ipv4.route.redirect_load = 20

One problem I ran into was that the Windows XP clients, after a time forgot the route and then need to be redirected again. However the default gateway router seemed to have stopped sending ICMP Redirects. I don’t know what the exact reason was, but a guess is that the redirect_number had been reached and the redirect silence time was so high that the router was not able to resend an ICMP Redirect soon enough.

So I have tried adding a lower redirect_silence value to /etc/sysctl.conf by placing net.ipv4.route.redirect_silence = 5120 in /etc/sysctl.conf and then running sysctl -p to load the value.

I am hoping this will stop the router from going silent due to hitting it’s redirect_number and redirect_load values.

I got the 5120 value from a Ubuntu 8.04 box. Which has these defaults

net.ipv4.route.redirect_load = 5
net.ipv4.route.redirect_number = 9
net.ipv4.route.redirect_silence = 5120

The original Fedora Core 1 Firewall which was in place before the CentOS had these defaults so 5120 seems alot closer than the CentOS 20480 value. I never had the ICMP Redirect going silent problem with FC1.

net.ipv4.route.redirect_silence = 2048
net.ipv4.route.redirect_number = 9
net.ipv4.route.redirect_load = 2


Submit a Comment

Your email address will not be published. Required fields are marked *

You May Also Like…

How to Research a CPU Upgrade

How to Research a CPU Upgrade

Upgrade Time! Doing a lot of VMWare Workstation virtualization to create labs for self-study and training. Finding...