or those starting out in their CCNP/CCIE Journey, I would like to address one of the most crucial parts of the CCIE Lab: Verifying full reachability.
It is common practice for any CCIE candidate to verify their reachability across the lab topology when labbing. While studying for the CCNP, I learned a couple short cuts:
TCL Scripts:
TCL Scripting is what you should use on your routers to ping multiple addresses without delay.
- To configure a TCL Script -
1. Enter TCL scripting
R3#tclsh
R3(tcl)#
2. Create the script
R3(tcl)#foreach address {
+>(tcl)#1.1.1.1
+>(tcl)#2.2.2.2
+>(tcl)#3.3.3.3
+>(tcl)#} { ping $address }
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 1.1.1.1, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1/1/1 ms
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 2.2.2.2, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1/1/1 ms
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 3.3.3.3, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1/1/4 ms
This is a great way of pinging a ton of addresses without having to manually enter each ping command and wait for its output. This saved me a lot of time on the verification during my Lab exam.
Much more in depth information on TCL Scripting in Cisco IOS can be found here:
http://www.cisco.com/en/US/docs/ios/12_3t/12_3t2/feature/guide/gt_tcl.html
Macro:
This can do a similar thing on a switch that TCL ping scripts will do on a router.
- To configure a ping macro -
1. Create the macro name and enter macro configuration mode:
Switch(config)#macro name PINGVERIFICATION
Enter macro commands one per line. End with the character '@'.
do ping 1.1.1.1
do ping 2.2.2.2
do ping 3.3.3.3
@
IOS is nice to us, in that it will tell you how to configure the macro.
2. Apply the macro:
Switch(config)#macro global apply PINGVERIFICATION
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 1.1.1.1, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1/2/8 ms
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 2.2.2.2, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1/1/1 ms
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 3.3.3.3, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1/2/8 ms
Another way to use a macro is for redundant configuration. For example, let's say we want to configure a bunch of switch ports with a particular port security policy:
Switch(config)#macro name PORTSEC
Enter macro commands one per line. End with the character '@'.
switchport mode access
switchport port-security
switchport port-security mac-address sticky
switchport port-security maximum 5
switchport port-security violation restrict
snmp trap mac-notification added
snmp trap mac-notification removed
@
What I have created here, is a macro that will do the following:
1. Set the port to access mode
2. Turn on port-security
3. Configure specific port-security policies
4. Enable SNMP trap notifications for whenever a MAC-address is added or removed
Now we can apply this macro to a switchport:
Switch(config)#interface fa0/7
Switch(config-if)#macro apply PORTSEC
Verify that the configurations have taken place:
Switch#show port-security interface fastEthernet 0/7
Port Security : Enabled
Port Status : Secure-down
Violation Mode : Restrict
Aging Time : 0 mins
Aging Type : Absolute
SecureStatic Address Aging : Disabled
Maximum MAC Addresses : 5
Total MAC Addresses : 0
Configured MAC Addresses : 0
Sticky MAC Addresses : 0
Last Source Address:Vlan : 0000.0000.0000:0
Security Violation Count : 0
Switch#show mac-address-table notification interface fa0/7
MAC Notification Feature is Disabled on the switch
Interface MAC Added Trap MAC Removed Trap
--------- -------------- ----------------
FastEthernet0/7 Enabled Enabled
Smart Port Macro:
Here is where things get cool. Now we can mix that normal macro with a smart port macro.
Let's say we wanted to apply that normal macro we created earlier to many interfaces with only a couple commands. This can be done using a Smart Port Macro:
1. Create a smart port macro using the "define" command. This is a preset configuration:
Switch(config)#define interface-range FA0/7-21 fastEthernet 0/7 - 21
Here I have defined the switchport range of fa 0/7 - 21.
2. Use the Smart Port Macro:
Switch(config)#interface range mac FA0/7-21
3. Call the normal macro we created earlier:
Switch(config-if-range)#macro apply PORTSEC
4. Verify your macro:
Switch#show parser macro
--------------------------------------------------------------
Macro name : PINGVERIFICATION
Macro type : customizable
do ping 1.1.1.1
do ping 2.2.2.2
do ping 3.3.3.3
--------------------------------------------------------------
Macro name : PORTSEC
Macro type : customizable
switchport mode access
switchport port-security
switchport port-security mac-address sticky
switchport port-security maximum 5
switchport port-security violation restrict
snmp trap mac-notification added
snmp trap mac-notification removed
--------------------------------------------------------------
If you are so interested, take a little bit of time and read through some of the pre-configured macros using the show parser macro command. There is some interesting stuff in there.
For more detailed information on Smart Port Macros visit:
http://www.cisco.com/en/US/docs/switches/lan/catalyst2940/software/release/12.1_19_ea1/configuration/guide/swmacro.pdf
No comments:
Post a Comment