This article will cover setting up redundant ISPs for outbound connectivity on an ASA 5510 (although the same should work on the 5520s and up as well). It’s important to note that this covers outbound
connectivity only. The ASA does not have built in functionality to NAT multiple public IPs to a single internal IP – for that you’d need a router (how-to article soon!). For an ASA to provide inbound redundancy to your servers you’d need to utilize two separate IPs for each server – one to be NAT’d to each public IP block.
The information you’ll need to complete this task:
Primary ISP Subnet / Gateway
Secondary ISP Subnet / Gateway
A Public host to ping (i.e. 184.108.40.206)
The Public host to ping is a device (read: cluster of devices) that we will use to check if our primary ISP is up or down. For that reason, I advise against using an IP of a single server. I usually go with one of the well-known public DNS servers – 220.127.116.11, 18.104.22.168, or 22.214.171.124.
For this article, we’ll use the following information:
I’ll assume that you’ve already been successful in getting your ASA up and running, and that your config looks something like this (NOTE: I’m using the 8.2 firmware):
description Primary ISP
ip address 126.96.36.199 255.255.255.0
description Backup ISP
ip address 188.8.131.52 255.255.255.0
description Private LAN
ip address 10.10.10.1 255.255.255.0
no ip address
ip address 192.168.1.1 255.255.255.0
global (backup) 1 interface
global (outside) 1 interface
nat (inside) 1 0.0.0.0 0.0.0.0
route outside 0.0.0.0 0.0.0.0 184.108.40.206 1
route backup 0.0.0.0 0.0.0.0 220.127.116.11 10
As it stands, you will fail over to your secondary ISP only if interface Eth0/0 physically goes down – that is, the cable to your upstream router, public switch, or whatever device you firewall is connected to is unplugged or cut. Realistically, the number of times that an outage is due to something besides a loss of physical link is far greater than an outage caused by a physical outage. For that reason, Cisco lets us do route tracking, which is where our “public IP to ping” comes into play. Basically, we tell the ASA that we want to ping IP address 18.104.22.168 over a specific route, and if that host stops responding, then assume the route is down, and install a backup route into the route table.
To get started, get into configuration mode
firewall# config t
First we’ll setup the constant ping to a specific IP:
firewall(config)# sla monitor 1
firewall(config-sla-monitor)# type echo protocol ipIcmpEcho 22.214.171.124 interface outside
firewall(config-sla-monitor)# num-packets 3
firewall(config-sla-monitor)# frequency 10
firewall(config)# sla monitor schedule 1 life forever start-time now
Here we’ve said that we want to send 3 ICMP echos to 126.96.36.199 and repeat every 10 seconds.
Next we’ll tie a tracked route with the SLA monitor:
firewall(config)# track 100 rtr 1 reachability
And last we’ll specify the route that we want to track:
firewall(config)# no route outside 0.0.0.0 0.0.0.0 188.8.131.52 1
firewall(config)# route outside 0.0.0.0 0.0.0.0 184.108.40.206 1 track 100
And that should do it. Keep in mind that for the best test case after completing this setup you should turn off / unplug something that leave the physical interface up. So if you’re firewall connects to a public switch, and then the switch connects to your ISP’s device, unplug the cable between the switch and the ISP.