Cisco 基于策略路由的配置实例

问题描述:您可以定义自己的规则来进行数据包的路由而不仅仅由目的地地址所决定。在这里您可以学到怎么使用基于策略路由的办法来解决这一问题。在具体的应用中,基于策略的路由有:
   基于源ip地址 的策略路由
   基于数据包大小的策略路由
   基于应用的策略路由
   通过缺省路由平衡负载
  这里,讲述了第一种情况的路由策略
  举例 : 在这个例子中,防火墙的作用是:把 10.0.0 .0/8 内部网地址翻译成可路由的 172.16.255.0/24 子网地址。
  

  下面的防火墙配置是为了完整性而加进去的,它不是策略路由配置所必需的。在这里的防火墙可以被其它类似的产品代替,如 PIX 或其它类似防火墙设备。这里的防火墙的配置如下:
     access-list 1 permit 10.0.0 .0 0.255.255.255
ip nat pool net-10 172.16.255.1 172.16.255.254 prefix-length 24
     ip nat inside source list 1 pool net-10
       interface Ethernet0
      ip address 172.16.20.2 255.255.255.0
      ip nat outside
        interface Ethernet1
      ip address 172.16.39.2 255.255.255.0
      ip nat inside
       router eigrp 1
     network 172.16.0.0
      default-metric 10000 100 255 1 1500
         ip route 172.16.255.0  255.255.255.0  Null0
    
        end
  
  在我们的例子中, Cisco WAN 路由器上运行策略路由来保证从 10.0.0 .0/8 网络来的 IP 数据包被发送到防火墙去。配置中定义了两条 net-10 策略规则。第一条策略就定义了从 10.0.0.0/8 网络来的 IP 数据包被发送到防火墙去(我们很快会看到这里的配置有问题)。而第二条规则允许所有的其它数据包能按正常路由。这里的 Cisco WAN 路由器的配置如下:

     interface Ethernet0/0
      ip  address 172.16.187.3 255.255.255.0
   
       interface Ethernet0/1
      ip  address 172.16.39.3 255.255.255.0
    
       interface Ethernet3/0
      ip  address 172.16.79.3 255.255.255.0
         ip  policy route-map net-10
       router eigrp 1
      network 172.16.0.0
          access-list 110 permit i p 10.0.0 .0 0.255.255.255 172.16.36.0 0.0.0.255
       access-list 111 permit i p 10.0.0 .0 0.255.255.255 any
         route-map net-10 permit 10
      match ip address 111
      set interface Ethernet0/1
          route-map net-10 permit 20
end
  我们可以这样测试我们所做的配置。在名为 Cisco-1 的路由器 10.1.1 .1 上发送 ping 命令到 Internet 上的一个主机(这里就是 192.1.1.1 主机)。要查看名为 Internet Router 的路由器上的情况,我们在特权命令模式下执行 debug ip packet 101 detail 命令。(其中,在此路由器上有 access-list 101 permit icmp any any 配置命令)。下面是输出结果:
   Results of ping from Cisco-1 to 192.1.1.1/internet taken from Internet_Router:
     Pakcet never makes it to Internet_Router
  正如您所看到的:数据包没有到达 Internet_Router 路由器。下面的在 Cisco WAN 路由器上的 debug 命令给出了原因:
  
     Debug commands run from Cisco_WAN_Router:
     "debug ip policy"
     2d15h: IP: s=10.1.1.1 (Ethernet3/0), d=192.1.1.1, len 100, policy match
     2d15h: IP: route map net-10, item 10, permit
     2d15h: IP: s=10.1.1.1 (Ethernet3/0), d=192.1.1.1 (Ethernet0/1), len 100, policy routed
     2d15h: IP: Ethernet3/0 to Ethernet0/1 192.1.1.1
  这里,数据包确实匹配了 net-10 策略图中的第一条规则。但为什么还是没有达到预期的目的呢?用 "debug arp" 来看一下。
     "debug arp"
     2d15h: IP ARP: sent req src 172.16.39.3 0010.7bcf.5b02,
                 dst 192.1.1.1 0000.0000.0000 Ethernet0/1
     2d15h: IP ARP rep filtered src 192.1.1.1 00e0.b064.243d, dst 172.16.39.3 0010.7bcf.5b02
          wrong cable, interface Ethernet0/1
   debug arp 的输出给出了原因。路由器努力完成它被指示要做的动作,而且试图把数据包发向 Ethernet0/1 接口,但失败了。这要求路由器为目的地址 192.1.1.1 执行地址解析协议操作,当执行该任务时,路由器知道了目的地址不处于该接口。接下来,路由器发生封装错误。所以,最后数据包不能到达 192.1.1.1
  我们怎样避免这个问题呢?修改路由图使防火墙地址为下一跳。
   Config changed . Cisco_WAN_Router:
     !
     route-map net-10 permit 10
      match ip address 111
      set ip next-hop 172.16.39.2
     !
  修改后,在 Internet Router 上运行同样的命令: debug ip packet 101 detail 。这时,数据包可以按配置前进。我们也能看到数据包被防火墙翻译成了 172.16.255.1 192.1.1.1 主机的回应:
  
     Results of ping from Cisco_1 to 192.1.1.1/internet taken from Internet_Router:
     2d15h: IP: s=172.16.255.1 (Ethernet1), d=192.1.1.1 (Serial0), g=192.1.1.1, len 100, forward
     2d15h: ICMP type=8, code=0
     2d15h:
     2d15h: IP: s=192.1.1.1 (Serial0), d=172.16.255.1 (Ethernet1), g=172.16.20.2, len 100, forward
     2d15h: ICMP type=0, code=0
     2d15h:
  在 Cisco WAN 路由器上执行 debug ip policy 命令后,我们可以看到数据包被传递到了防火墙, 172.16.39.2
  
     Debug commands run from Cisco_WAN_Router:
     "debug ip policy"
     2d15h: IP: s=10.1.1.1 (Ethernet3/0), d=192.1.1.1, len 100, policy match
     2d15h: IP: route map net-10, item 20, permit
     2d15h: IP: s=10.1.1.1 (Ethernet3/0), d=192.1.1.1 (Ethernet0/1), len 100, policy routed
     2d15h: IP: Ethernet3/0 to Ethernet0/1 172.16.39.2
  

你可能感兴趣的:(职场,Cisco,路由器,路由,休闲)