July 14, 2022
	
	
	Filed Under: Linux| Tags: linux, NAT	
	
	
I was recently working on a Linux system that was providing a NAT service for an environment.  Initially, everything seemed to be working fine, but after some additional testing problems were discovered…
What was happening was that network traffic was coming into one interface, but this interface didn’t have a route back to the source system, and so the reply traffic needed to go out the default network interface, as expected.  The problem (feature!) though is that newer Linux versions have a feature called Strict Reverse Path Forwarding, which checks to be sure that the interface receiving traffic is able to also able respond to this traffic.  For a local subnet, this is usually fine, but for traffic outside of the local subnet, this requires routing, quite possibly by another network interface.  And with the Strict Reverse Path Forwarding enabled, if traffic needs to bounce to another interface, then the packet gets dropped.  For more info on this, see this link: https://access.redhat.com/solutions/53031